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Apresentação 


O livro proposto tem como objetivos: 
apresentar técnicas para a elaboração de algoritmos; 
apresentar comandos para a implementação de algoritmos nas linguagens PASCAL, C/C++ e 
JAVA; 
apresentar a solução de problemas em algoritmos e em programas escritos em PASCAL, C/C++ e 
JAVA; 
incentivar os leitores à programação por meio da proposição de várias situações-problema ao final 
de cada capítulo. 


Todos os capítulos apresentarão nas seções iniciais conceitos teóricos sobre a utilização de algum recur- 
so de computação em algoritmos e nas linguagens de programação PASCAL, C/C++ e JAVA. 

A penúltima seção de cada capítulo apresenta uma série de problemas resolvidos em algoritmos, PASCAL, 
C/C++ e também em JAVA, e, na última, o leitor encontrará uma série de problemas para serem resolvidos. 

Nesta edição, além da revisão completa da obra, foram acrescentados dois capítulos. O Capítulo 12, 
com uma introdução à programação orientada a objetos, e o Capítulo 13, com vários problemas desafiado- 
res, envolvendo o conteúdo discutido em todo o livro. 


RELEVÂNCIA, ATUALIDADE E PÚBLICO-ALVO 


Durante alguns anos em que ensinamos fundamentos da programação de computadores, temos obser- 
vado a grande dificuldade dos alunos em assimilar estes novos conceitos e em adquirir habilidades que lhes 
permitam resolver problemas reais relacionados à programação. 

Observamos também que, através da análise aprofundada de problemas já resolvidos, os estudantes 
conseguem superar parte dessas dificuldades, além de adquirirem maior motivação para os estudos. 

Esta obra será aproveitada por alunos iniciantes na programação de computadores, visto que as lingua- 
gens PASCAL, C/C++ e JAVA são muito utilizadas no início da programação por serem de fácil compre- 
ensão e ótimas para despertar o raciocínio lógico nos alunos. 

Esta obra se diferencia das demais por possuir uma grande quantidade de exercícios resolvidos e propos- 
tos após cada capítulo, o que possibilita sua utilização em aulas de laboratório, uma prática muito comum 
nas universidades atualmente. 


No Companion Website deste livro (www.pearson.com.br/ascencio campos), professores e alu- 
nos obtêm a resolução dos exercícios apresentados em cada capítulo em PASCAL, C/C++ e JAVA, 
incluindo fontes e executáveis. 
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CAPÍTULO 


Conceitos 


básicos 


Desde o início de sua existência, o homem procurou criar máquinas que o auxiliassem em seu trabalho, 
diminuindo o esforço e economizando tempo. Dentre essas máquinas, o computador vem se mostrando 
uma das mais versáteis, rápidas e seguras. 

O computador pode auxiliá-lo em qualquer tarefa. É consciente, trabalhador, possui muita energia, 
mas não tem iniciativa, nenhuma independência, não é criativo nem inteligente, por isso, precisa receber 
instruções nos mínimos detalhes. 

A finalidade de um computador é receber, manipular e armazenar dados. Visto somente como um gabi- 
nete composto por circuitos eletrônicos, cabos e fontes de alimentação, certamente ele parece não ter nenhu- 
ma utilidade. O computador só consegue armazenar dados em discos, imprimir relatórios, gerar gráficos, 
realizar cálculos, entre outras funções, por meio de programas, portanto, sua finalidade principal é realizar 
a tarefa de processamento de dados, isto é, receber dados por um dispositivo de entrada (por exemplo, te- 
clado, mouse, scanner etc.), realizar operações com esses dados e gerar uma resposta que será expressa em 
um dispositivo de saída (por exemplo, impressora, monitor de vídeo, entre outros) (ASCENCIO, 1999). 

Logo, um computador possui duas partes diferentes que trabalham juntas: o hardware, composto pelas 
partes físicas, e o software, composto pelos programas. 

Quando queremos criar ou desenvolver um software para realizar determinado tipo de processamento 
de dados, devemos escrever um programa ou vários programas interligados. No entanto, para que o com- 
putador compreenda e execute esse programa, devemos escrevê-lo usando uma linguagem que tanto o com- 
putador quanto o criador de software entendam. Essa linguagem é chamada linguagem de programação. 

As etapas para o desenvolvimento de um programa são: 


Análise: estuda-se o enunciado do problema para definir os dados de entrada, o processamento e 
os dados de saída. 


Algoritmo: ferramentas do tipo descrição narrativa, fluxograma ou português estruturado são uti- 
lizadas para descrever o problema com suas soluções. 


Codificação: o algoritmo é transformado em códigos da linguagem de programação escolhida para 
se trabalhar. 
Portanto, um programa é a codificação de um algoritmo em uma linguagem de programação (ASCEN- 
CIO, 1999). 


1.1 Conceito de algoritmo 


A seguir, apresentamos alguns conceitos de algoritmos: 

“Algoritmo é uma sequência de passos que visa atingir um objetivo bem definido” (FORBELLONE, 1999). 

“Algoritmo é a descrição de uma sequência de passos que deve ser seguida para a realização de uma 
tarefa” (ASCENCIO, 1999). 

“Algoritmo é uma sequência finita de instruções ou operações cuja execução, em tempo finito, resolve 
um problema computacional, qualquer que seja sua instância” (SALVETTI, 1999). 

“Algoritmos são regras formais para a obtenção de um resultado ou da solução de um problema, en- 
globando fórmulas de expressões aritméticas” (MANZANO, 1997). 
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“Ação é um acontecimento que, a partir de um estado inicial, após um período de tempo finito, produz 
um estado final previsível e bem definido. Portanto, um algoritmo é a descrição de um conjunto de coman- 
dos que, obedecidos, resultam numa sucessão finita de ações” (FARRER, 1999). 

Analisando as definições anteriores, podemos perceber que executamos no dia a dia vários algoritmos, 
como se pode observar nos exemplos a seguir. 


Algoritmo 1 — Somar três números 
Passo 1 — Receber os três números. 
Passo2 — Somar os três números. 
Passo3 — Mostrar o resultado obtido. 
Algoritmo 2 — Fazer um sanduíche 
Passo 1 — Pegar o pão. 
Passo2 — Cortar o pão ao meio. 
Passo3 — Pegar a maionese. 
Passo 4 — Passar a maionese no pão. 
Passo 5 — Pegar e cortar alface e tomate. 
Passo 6 — Colocar alface e tomate no pão. 
Passo7 — Pegar o hambúrguer. 
Passo 8 — Fritar o hambúrguer. 
Passo9 — Colocar o hambúrguer no pão. 
Algoritmo 3 — Trocar uma lâmpada 
Passo 1  — Pegar uma lâmpada nova. 
Passo2 | — Pegar uma escada. 
Passo3 | — Posicionar a escada embaixo da lâmpada queimada. 
Passo 4  — Subir na escada com a lâmpada nova na mão. 
Passo 5 — Retirar a lâmpada queimada. 
Passo 6 | — Colocar a lâmpada nova. 
Passo 7 — Descer da escada. 
Passo 8 — Testar o interruptor. 
Passo9 | — Guardar a escada. 
Passo 10 — Jogar a lâmpada velha no lixo. 
Algoritmo 4 — [r para a escola 
Passo 1 — Acordar cedo. 
Passo2 — Ir ao banheiro. 
Passo3 — Abrir o armário para escolher uma roupa. 
Passo 4 — Seo tempo estiver quente, pegar uma camiseta e uma calça jeans; Caso contrário, 
pegar um agasalho e uma calça jeans. 
Passo 5 — Vestir a roupa escolhida. 
Passo 6 — Tomar café. 
Passo 7 — Pegar uma condução. 
Passo 8 — Descer próximo à escola. 
Algoritmo 5 — Sacar dinheiro no banco 24 horas 
Passo 1 — Ir até um banco 24 horas. 
Passo2 — Colocar o cartão. 
Passo3 — Digitar a senha. 
Passo 4 — Solicitar a quantia desejada. 
Passo § — Seo saldo for maior ou igual à quantia desejada, sacar; caso contrário, mostrar 
mensagem de impossibilidade de saque. 
Passo 6 — Retirar o cartão. 


Passo 7 — Sair do banco 24 horas. 
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QOQ Observação 


Você pode estar pensando: “Mas eu realizo essas atividades de maneira diferente!” . Esse pensamen- 
to está correto, pois, às vezes, um problema pode ser resolvido de diversas maneiras, porém, gerando a 
mesma resposta. Ou seja, podem existir vários algoritmos para solucionar o mesmo problema. 


1.2 Método para a construção de algoritmos 


Para a construção de qualquer tipo de algoritmo, é necessário seguir estes passos: 


Compreender completamente o problema a ser resolvido, destacando os pontos mais importantes 
e os objetos que o compõem. 


Definir os dados de entrada, ou seja, quais dados serão fornecidos e quais objetos fazem parte desse 
cenário problema. 


Definir o processamento, ou seja, quais cálculos serão efetuados e quais as restrições para esses cál- 
culos. O processamento é responsável pela transformação dos dados de entrada em dados de saída. 
Além disso, deve-se verificar quais objetos são responsáveis pelas atividades. 


Definir os dados de saída, ou seja, quais dados serão gerados depois do processamento. 
Construir o algoritmo utilizando um dos tipos descritos na próxima seção. 
Testar o algoritmo realizando simulações. 


1.3 Tipos de algoritmos 


Os três tipos mais utilizados de algoritmos são: descrição narrativa, fluxograma e pseudocódigo ou 
portugol, que descrevemos a seguir. 


13.1 Descrição narrativa 
A descrição narrativa consiste em analisar o enunciado do problema e escrever, utilizando uma lingua- 
gem natural (por exemplo, a língua portuguesa), os passos a serem seguidos para sua resolução. 
Vantagem: não é necessário aprender nenhum conceito novo, pois uma língua natural, neste ponto, já 
é bem conhecida. 


Desvantagem: a língua natural abre espaço para várias interpretações, o que posteriormente dificultará 
a transcrição desse algoritmo para programa. 


13.2 Fluxograma 

O fluxograma consiste em analisar o enunciado do problema e escrever, utilizando símbolos gráficos 
predefinidos (Tabela 1.1), os passos a serem seguidos para sua resolução. 

Vantagem: o entendimento de elementos gráficos é mais simples que o entendimento de textos. 


Desvantagem: é necessário aprender a simbologia dos fluxogramas e, além disso, o algoritmo resultante 
não apresenta muitos detalhes, dificultando sua transcrição para um programa. 


13.3 Pseudocódigo ou portugol 
O pseudocódigo ou portugol consiste em analisar o enunciado do problema e escrever, por meio de 
regras predefinidas, os passos a serem seguidos para sua resolução. 
Vantagem: a passagem do algoritmo para qualquer linguagem de programação é quase imediata, bas- 
tando conhecer as palavras reservadas da linguagem que será utilizada. 


Desvantagem: é necessário aprender as regras do pseudocódigo, que serão apresentadas nos próximos 
capítulos. 
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Tabela 1.1 Conjunto de símbolos utilizados no fluxograma. 


(0) Símbolo utilizado para indicar o início e o fim do algoritmo. 


Símbolo que permite indicar o sentido do fluxo de dados. Serve exclusivamente 
para conectar os símbolos ou blocos existentes. 


| Símbolo utilizado para indicar cálculos e atribuições de valores. 


E ú Símbolo utilizado para representar a entrada de dados. 


PE Símbolo utilizado para representar a saída de dados. 


Símbolo utilizado para indicar que deve ser tomada uma decisão, apontando a 
possibilidade de desvios. 


1.4 Exemplos de algoritmos 


Os exemplos a seguir mostram alguns algoritmos desenvolvidos com os três tipos citados anteriormente. 
a) Faça um algoritmo para mostrar o resultado da multiplicação de dois números. 


Algoritmo em descrição narrativa: 
Passo 1 — Receber dois números que serão multiplicados. 
Passo 2 — Multiplicar os números. 


Passo 3 — Mostrar o resultado obtido na multiplicação. 


Algoritmo em fluxograma: 


INÍCIO / N1, N2 / 


M=N1 * N2 


Algoritmo em pseudocódigo: 


ALGORITMO 

DECLARE N1, N2, M NUMÉRICO 
ESCREVA “Digite dois números” 
LEIA N1, N2 

M — N1 * N2 

ESCREVA “Multiplicação = “, M 
FIM ALGORITMO. 
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b) Faça um algoritmo para mostrar o resultado da divisão de dois números. 


Algoritmo em descrição narrativa: 


Passo 1 — Receber os dois números que serão divididos. 
Passo2 — Seo segundo número for igual a zero, não poderá ser feita a divisão, pois não existe 
divisão por zero; caso contrário, dividir os números e mostrar o resultado da divisão. 


Algoritmo em fluxograma: 


Não panim o | 


SIM IMPOSSIVEL FIM 


DIVIDIR 


Algoritmo em pseudocódigo: 


ALGORITMO 

DECLARE N1, N2, D NUMÉRICO 
ESCREVA “Digite dois números” 
LEIA N1, N2 

SE N2 = 0 

ENTÃO ESCREVA “Impossível dividir” 
SENÃO INÍCIO 


D — N1/N2 
ESCREVA “Divisão = “, D 
FIM 


FIM_ALGORITMO. 


c) Faça um algoritmo para calcular a média aritmética entre duas notas de um aluno e mostrar sua situa- 
ção, que pode ser aprovado ou reprovado. 


Algoritmo em descrição narrativa: 


Passo 1 — Receber as duas notas. 

Passo2 — Calcular a média aritmética. 

Passo 3 — Mostrar a média aritmética. 

Passo 4 — Sea média aritmética for maior ou igual a 7, então a situação do aluno é aprovado; caso 


contrário, a situação é reprovado. 
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Algoritmo em fluxograma: 


NES )—/ ne 7 


FERA 


| 


| 
| 


E 


APROVADO | €<—— ——> | REPROVADO 
SIM NAO 


Algoritmo em pseudocódigo: 


ALGORITMO 

DECLARE N1, N2, M NUMÉRICO 
ESCREVA “Digite as duas notas” 
LEIA N1, N2 

M — (N1 + N2)/2 

ESCREVA “Média =", M 

SE M > 7 

ENTÃO ESCREVA “Aprovado” 

SENÃO ESCREVA “Reprovado” 

FIM ALGORITMO. 


d) Faça um algoritmo para calcular o novo salário de um funcionário. Sabe-se que os funcionários que 
recebem atualmente salário de até R$ 500 terão aumento de 20%; os demais terão aumento de 10%. 


Algoritmo em descrição narrativa: 


Passo 1 — Receber o salário atual do funcionário. 

Passo2 — Seo salário atual do funcionário for de até R$ 500, calcular o novo salário com per- 
centual de aumento de 20%; caso contrário, calcular o novo salário com percentual 
de aumento de 10%. 
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Algoritmo em fluxograma: 


Novo SAL= | SIM AL ATUA NÃO. | NOVO SAL= 
e —— 


SAL_ATUAL * 1,20 < SAL ATUAL * 1,10 
500 


NOVO SAL —>( mM ) <«—— | NOVO SAL 


Algoritmo em pseudocódigo: 


ALGORITMO 

DECLARE SAL ATUAL, NOVO SAL NUMÉRICO 

ESCREVA “Digite o salário atual do funcionário” 
LEIA SAL ATUAL 

SE SAL ATUAL < 500 

ENTÃO NOVO SAL + SAL ATUAL * 1,20 

SENÃO NOVO SAL + SAL ATUAL * 1,10 

ESCREVA “Novo salário =”, NOVO SAL 

FIM ALGORITMO. 


1.5 Conceito de variável 


Duas pessoas estão conversando e precisam realizar uma conta. A primeira pessoa diz: “Vamos so- 
mar dois números”. E continua: “O primeiro número é 5”. A segunda pessoa guarda o primeiro número 
na cabeça, ou seja, na memória. À primeira pessoa diz: “O segundo número é 3”. A segunda pessoa 
também guarda o segundo número na cabeça, sem esquecer o primeiro número, ou seja, cada número foi 
armazenado em posições diferentes da memória humana, sem sobreposição. A primeira pessoa pergunta: 
“Qual é o resultado da soma?” A segunda pessoa resgata os valores armazenados na memória, realiza a 
conta e responde dizendo que o resultado é 8. 

Um algoritmo e, posteriormente, um programa recebem dados que precisam ser armazenados no com- 
putador para serem utilizados no processamento. Esse armazenamento é feito na memória. Todos os com- 
putadores trabalham com sistema numérico binário e, nesse sistema, os dados são transformados em O e 
1 ('zeros” e *uns”) para, então, serem armazenados na memória. Cada dígito binário (0 ou 1) ocupa uma 
porção de memória chamada bit, e um conjunto de 8 bits é denominado byte. Cada byte é identificado e 
acessado por meio de um endereço. 

Todos os caracteres existentes possuem um correspondente numérico na tabela ASCII, transformado 
em caractere binário pelo método da divisão para, então, ser armazenado na memória. Dessa maneira, uma 
variável representa uma posição de memória, que possui nome e tipo e seu conteúdo pode variar ao longo 
do tempo, durante a execução de um programa. Embora uma variável possa assumir diferentes valores, ela 
só pode armazenar um valor a cada instante. 


8 | Fundamentos da programação de computadores 


À seguir, um pedaço da tabela ASCII: 


Tabela 1.2 Amostra da tabela ASCII. 


Caractere Valor decimal na tabela ASCII 
A 65 
B 66 
Ç 67 


Exemplo de transformação em binário: 


F=70 


F = 70 = 01000110 


Valor binário 
01000001 
01000010 
01000011 


Todo computador possui uma tabela de alocação que contém o nome da variável, seu tipo (para saber 
quantos bytes ocupará) e seu endereço inicial de armazenamento. Dessa maneira, quando queremos buscar 
algum dado na memória, basta sabermos o nome da variável, que o computador, por meio da tabela de 


alocação, busca automaticamente. 


1.6 Tipos de dados 


Os tipos de dados mais utilizados são: numéricos, lógicos e literais ou caracteres, que descreveremos a 


seguir. 


1.6.1 Numéricos 


Os dados numéricos dividem-se em dois grupos: inteiros e reais. 
Os números inteiros podem ser positivos ou negativos e não possuem parte fracionária. Exemplos de 


dados numéricos inteiros: 


—23 
98 
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Os números reais podem ser positivos ou negativos e possuem parte fracionária. Exemplos de dados 
numéricos reais: 


23.45 
346.89 
—34.88 


0.0 
—247.0 


QOQ Observação 


Os números reais seguem a notação da língua inglesa, ou seja, a parte decimal é separada da parte 
inteira por um ponto, e não por uma vírgula. 


1.6.2 Lógicos 
São também chamados dados booleanos (oriundos da álgebra de Boole) e podem assumir os valores 
verdadeiro ou falso. 


16.3 Literais ou caracteres 

São dados formados por um único caractere ou por uma cadeia de caracteres. Esses caracteres po- 
dem ser as letras maiúsculas, as letras minúsculas, os números (não podem ser usados para cálculos) e os 
caracteres especiais (&, É, O, 2, +). 


Exemplos de dados literais: 


“aluno” 
“1234” 

“Q internet” 
“0.34” 

A Alt 

EN 

TIE 


QOQ Observação 


Um caractere é representado entre apóstrofos e um conjunto de caracteres é representado entre aspas. 


1.7 Formação de identificadores 
Os identificadores são os nomes das variáveis, dos programas, das constantes, das rotinas, das unidades 

etc. As regras básicas para a formação dos identificadores são: 

Os caracteres permitidos são: os números, as letras maiúsculas, as letras minúsculas e o caractere 

sublinhado. 

O primeiro caractere deve ser sempre uma letra ou o caractere sublinhado. 

Não são permitidos espaços em branco e caracteres especiais (OD, $, +, —, %, !). 

Não podemos usar as palavras reservadas nos identificadores, ou seja, palavras que pertençam à 

linguagem de programação. 
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1.8 Exemplos de identificadores 


Exemplos de identificadores válidos: 


A 

a 

nota 
NOTA 
X5 

A32 
NOTAÍ 
MATRICULA 
nota 1 
dia 
IDADE 


Exemplos de identificadores inválidos: 


5b — por começar com número; 

e 12 — por conter espaço em branco; 

x-y — por conter o caractere especial —; 

prova 2n — por conter espaço em branco; 
nota(2) — por conter os caracteres especiais (); 
case — por ser palavra reservada; 

SET — por ser palavra reservada. 


1.9 Linguagem PASCAL 


A linguagem PASCAL foi desenvolvida em 1968 por Niklaus Wirth, na Suíça, destinada principalmente 
à programação científica, mas sua grande evolução permitiu que, nos dias de hoje, seja utilizada para qual- 
quer fim. Essa linguagem possui um ambiente integrado de desenvolvimento chamado Turbo Pascal com as 
seguintes características: 


Apresenta um editor que permite ao desenvolvedor digitar, salvar e modificar o código de seus 
programas. 

Possui um compilador que converte os códigos dos programas em instruções de máquina e verifica 
a existência de erros de sintaxe. 

Dispõe de um depurador que permite inspecionar um programa durante sua execução, facilitando 
a localização de erros. 


Conta com um sistema de ajuda ativo que oferece diferentes níveis de informação. 


Possui ainda o ambiente de execução propriamente dito, que permite executar os programas sem 
sair do Turbo Pascal (arquivos de extensão PAS) ou, se preferir, permite gerar arquivos a serem 
executados fora do ambiente do Turbo Pascal (arquivos de extensão EXE). 


1.10 Linguagem C/C++ 


Segundo Schildt (1996), Dennis Ritchie inventou a linguagem C e foi o primeiro a implementá-la usan- 
do um computador DEC PDP-11, que utilizava o sistema operacional Unix. Essa linguagem é resultante 
de um processo evolutivo de linguagens, cujo marco inicial foi uma linguagem chamada BCPL, desenvol- 
vida por Martin Richards, que teve forte influência em uma linguagem denominada B, inventada por Ken 
Thompson. Na década de 1970, B levou ao desenvolvimento de C. 

Durante alguns anos, o padrão da linguagem C foi aquele fornecido com a versão 5 do sistema opera- 
cional Unix, mas, com a popularização dos microcomputadores, várias implementações de C foram criadas, 
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gerando, assim, muitas discrepâncias. Para resolver tal situação, o American National Standards Institute 
(Ansi) estabeleceu, em 1983, um comitê para definir um padrão que guiasse todas as implementações da 
linguagem C. 

A linguagem C++ é uma extensão da linguagem C, e as instruções que fazem parte desta última re- 
presentam um subconjunto da primeira. Os incrementos encontrados na linguagem C++ foram feitos para 
dar suporte à programação orientada a objetos, e a sintaxe dessa linguagem é basicamente a mesma da 
linguagem C. 


1.11 Linguagem JAVA 


A tecnologia JAVA é composta pela linguagem de programação JAVA e pela plataforma de desenvolvi- 
mento JAVA. Essa linguagem de programação possui como principais características: simplicidade, orienta- 
ção a objetos, portabilidade, alta performance e segurança. 

Nessa linguagem, os programas são escritos em arquivos texto com a extensão .java e, ao serem compi- 
lados com o compilador javac, são gerados os arquivos .class. Um arquivo .class é constituído por bytecodes, 
código interpretado pela Máquina Virtual Java (Java Virtual Machine). 

Uma plataforma é um ambiente composto por hardware e software, ou seja, um sistema operacional 
e o hardware com o qual se comunica. À plataforma JAVA, entretanto, é composta apenas por software, 
uma vez que é a Máquina Virtual Java que faz a interface entre os programas e o sistema operacional. A 
plataforma JAVA é composta: 


pela Máquina Virtual Java, responsável por fazer a interface entre seu programa e o sistema opera- 
cional, transformando os bytecodes (comuns a qualquer ambiente) em código nativo reconhecido 
pelo hardware; e 

pela Application Programming Interface (API) JAVA, composta por amplo conjunto de classes já im- 
plementadas e testadas que fornecem variados recursos aos desenvolvedores. 


Figura 1.1 Processo de execução de um programa em JAVA. 


Compilador 
javac 


Máquina 
Virtual Java 


E 
MeuProg.java MeuProg.class 
Código nativo 


CAPÍTULO 


Paradigmas de 


programação 


Um paradigma de programação está intimamente relacionado à forma de pensar do programador e 
como ele busca a solução para os problemas. É o paradigma que permite ou proíbe a utilização de algumas 
técnicas de programação. Ele é capaz, ainda, de mostrar como o programador analisou e abstraiu o proble- 
ma a resolver. Existem vários paradigmas de programação: estruturado, orientado a objetos, lógico, fun- 
cional, dentre outros. Vamos analisar com mais detalhe os paradigmas estruturado e orientado a objetos. 

Pelo paradigma estruturado (também conhecido como imperativo ou procedural), qualquer problema 
pode ser quebrado em problemas menores, de mais fácil solução, chamados de sub-rotinas ou funções. 
Cada sub-rotina ou função pode receber valores de entrada, submetê-los a um processo capaz de gerar um 
valor de saída para quem fez uso da sub-rotina ou função. O paradigma estruturado preconiza, ainda, que 
todo processamento pode ser realizado pelo uso de três tipos de estrutura: sequencial, condicional e itera- 
tiva (de repetição). 

Já o paradigma orientado a objetos compreende o problema como uma coleção de objetos interagindo 
por meio de trocas de mensagem. Os objetos são estruturas de dados contendo estado (dados) e comporta- 
mento (lógica). Dessa maneira, um conjunto de objetos com informações comuns e com o mesmo compor- 
tamento dá origem a uma classe. 

Além disso, um programador que utilize o paradigma estruturado analisa o problema tentando relacio- 
nar as ações que deverão ser executadas e como poderão ser subdivididas em módulos. Um programador 
que utilize o paradigma orientado a objetos analisa o mesmo problema tentando identificar os objetos que 
compõem essa realidade e como eles interagem entre si. 

É importante destacar que o paradigma de programação está ligado à forma de pensar do programador. 
É possível ver, por exemplo, que o uso de uma linguagem com suporte nativo à orientação a objetos não 
implica, necessariamente, a criação de uma aplicação orientada a objetos. Também, podem-se encontrar 
facilmente soluções não estruturadas, construídas a partir de linguagens de programação com suporte à 
estruturação. 

Verificaremos, agora, por meio de um exemplo, a aplicação dos dois paradigmas na resolução de um 
mesmo problema no qual devemos calcular a área e o perímetro de um retângulo. Para isso, deverá existir 
uma interface com o usuário pela qual serão informadas as medidas dos lados do retângulo e visualizado o 
resultado de cada cálculo realizado. Trata-se de um problema simples, mas como resolvê-lo? 

Segundo o paradigma estruturado, devemos detalhar as ações necessárias para chegar à resposta dese- 
jada. Nesse sentido, devemos: 


Obter o valor da altura do retângulo. 
Obter o valor da largura do retângulo. 
Calcular a área. 

Calcular o perímetro. 


nv na 


. Mostrar os cálculos realizados. 
Posteriormente, devemos analisar a melhor forma de modularizar a solução. A ideia é que cada módulo 
realize uma tarefa bem específica, maximizando, assim, a possibilidade de ser reutilizado. 
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Cada módulo poderá receber valores e, também, devolver um valor a quem o solicitou. Nesse exemplo, 
nossa solução será composta por quatro módulos: o principal, pelo qual a execução começará; o calcula A- 
rea, responsável por calcular e devolver o valor da área do retângulo; o calculaPerimetro, responsável por 
calcular e devolver o valor do perímetro do retângulo; e o mostrarMensagem, responsável por mandar para 
a interface com o usuário o resultado dos cálculos realizados. 


Em PASCAL, usando o paradigma estruturado, a solução ficaria da seguinte forma: 


program exemplo; 
uses crt; 
var altura, largura, area, perimetro: real; 


function calculaArea(a, b:real):real; 
begin 

calculaArea := a * b; 

end; 


function calculaPerimetro(a, b:real):real; 
begin 

calculaPerimetro := 2*a + 2*b; 

end; 


procedure mostraMensagem(msg: string; vlr:real); 
begin 

writeln(msg, vlr:5:2); 

end; 


begin 

clrscr; 

write('Digite o valor da altura do retângulo: '); 
readlin(altura); 

write('Digite o valor da largura do retângulo: '); 
readin (largura); 


area := calculaArea(altura, largura); 

perimetro := calculaPerimetro(altura, largura); 
mostraMensagem('O valor da área , ', area); 
mostraMensagem('O valor do perímetro , ', perimetro); 
readln; 

end. 


Em JAVA, usando o paradigma estruturado, a solução ficaria como se segue: 


import java.io.*; 

import java.util.*; 

class Retangulo ( 

public static void main(String[] args) { 

float altura, largura, area, perimetro; 
Scanner entrada; 
entrada = new Scanner (System. in); 
System.out.print(“Digite o valor da altura do retângulo: “); 
altura = entrada.nextFloat(); 
System.out.print(“Digite o valor da largura do retângulo: “); 
largura = entrada.nextFloat(); 
area = calculaArea(altura, largura); 
perimetro = calculaPerimeto (altura, largura); 
mostraMensagem(“0O valor da área é ”, area); 
mostraMensagem( “O valor do perímetro é ”, perimetro); 


14 | Fundamentos da programação de computadores 


Í 
public static float calculaArea(float a, float b) { 


return a * b; 

} 

public static float calculaPerimetro(float a, float b) { 
return 2 *a + 2* Db; 

} 

public static void mostraMensagem(String msg, float vlr) { 
System.out.printin(msgtvlr); 


Em C++, fazendo uso do paradigma estruturado, a solução ficaria assim: 


finclude <stdio.h> 

float calculaArea(float a, float b) 

{ return a*b; 

i; 

float calculaPerimetro(float a, float b) 

{ return 2*a + 2*b; 

} 

void mostraMensagem(char *msg, float vilr) 

{ printf (“%s %5.2f"”, msg, vlr); 

l 

int main() 

{ float altura, largura, area, perimetro; 
printf(“Digite o valor da altura do retângulo: “); 
scanf(“Sf$*c”, saltura); 
printf(“Digite o valor da largura do retângulo: “); 
scanf (“sf%*c", alargura); 
area = calculaArea(altura, largura); 
perimetro = calculaPerimetro(altura, largura); 
mostraMensagem(“O valor da área é ”, area); 
mostraMensagem(“O valor do perímetro é ”, perimetro); 
return 0; 


Mesmo sendo um exemplo bastante simples, pode-se ver que a sub-rotina mostrarMensagem, presente 
nas três versões, é posta em execução por duas vezes, variando-se os parâmetros informados. Isso repre- 
senta uma das bases do paradigma estruturado, em que o problema é quebrado em pequenos módulos, 
para aumentar a capacidade de ser reutilizado (ou seja, escreve-se uma vez e utiliza-se quantas vezes forem 
necessárias). 

O paradigma orientado a objetos afirma que a solução de qualquer problema pode ser encontrada por 
meio das seguintes etapas: 


1. Procurar por objetos existentes no problema. 
2. Determinar as características e responsabilidades de cada objeto. 


3. Estabelecer como ocorrerá a interação entre os objetos identificados. 

Assim, pelo que foi apresentado e analisado no exemplo, observamos a existência de dois objetos: o 
retângulo e a interface com o usuário. 

O objeto retângulo tem a obrigação de armazenar e manipular o valor da altura e da largura, além de 
calcular a área e o perímetro. 

A janela tem a obrigação de receber os valores iniciais (altura e largura) e enviá-los para o retângulo. 
Depois disso, deve solicitar os valores da área e do perímetro ao objeto retângulo para mostrá-los. 
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Em PASCAL, usando o paradigma orientado a objetos, a solução ficaria da seguinte forma: 
program exemplo; 
uses crt; 
type retangulo = object 
altura, largura: real; 
procedure Inicializar altura; 
procedure Inicializar largura; 
function CalculaArea(alt, lar: real):real; 
function CalculaPerimetro(alt, lar: real):real; 
procedure MostrarMensagem(texto: string; valor:real); 
end; 
procedure retangulo. Inicializar altura; 
begin 
writeln('Digite o valor da altura do retângulo:'); 
readlin(altura); 
end; 
procedure retangulo. Inicializar largura; 
begin 
writeln('Digite o valor da largura do retângulo:'); 
readlin(largura); 
end; 
function retangulo.CalculaArea(alt,lar: real):real; 
begin 
CalculaArea := alt * lar; 
end; 
function retangulo.CalculaPerimetro(alt, lar: real):real; 
begin 
CalculaPerimetro := 2*alt + 2*lar; 
end; 
procedure retangulo.MostrarMensagem(texto: string; valor: real); 
begin 
writeln(texto,valor:5:2); 
end; 
var ret: retangulo; (instanciando um objeto da classe retangulo) 
begin { programa principal) 
clrscr; 
ret.Inicializar altura; 
ret.Inicializar largura; 
ret .MostrarMensagem('O valor da área = ',ret.CalculaArea(ret.altura, ret.largura)); 
ret .MostrarMensagem('0O valor do perímetro = ',ret.CalculaPerimetro( 
= ret.altura,ret.largura)); 
readln; 
end. 


Em C++, usando o paradigma orientado a objetos, a solução utilizaria dois arquivos: um com a ex- 
tensão .hpp, correspondendo à definição da classe Retangulo, e outro correspondendo classe Janela seria 
representado por um arquivo com a extensão .cpp. 
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Arquivo Retangulo. hpp 


class Retangulo 
{ private: 
float altura; 
float largura; 
public: 
Retangulo() 
{ altura = 0; 
largura = 0; 
l; 
float getAltura() 
{ return altura; 
} 
void setAltura(float a) 
{ altura = a; 
} 
float getLargura() 
{ return largura; 
} 
void setLargura(float 1) 
{ largura = 1; 
} 
float calculaArea() 
{ return altura * largura; 
; 
float calculaPerimetro() 
{ return 2*altura + 2*largura; 
} 
ki; 


Arquivo Janela.cpp 


include <stdio.h> 
include <iostream> 
include “Retangulo.hpp” 
using namespace std; 
void mostraMensagem(string msg, float vlr) 
{ 
cout << msg << vlr << “in”; 


} 


int main() 


{ Retangulo r; 
float altura, largura, area, perimetro; 


printf(“Digite o valor da altura do retângulo: “); 


scanf(“Sf$+*c”, saltura); 


printf(“Digite o valor da largura do retângulo: “); 


scanf(“Sf%+*c”, alargura); 
r.setAltura(altura); 
r.setLargura (largura); 


mostraMensagem(“0O valor da área é ”, r.calculaArea()); 


mostraMensagem(“O valor do perímetro é ”, 


return 0; 


r.calculaPerimetro()); 
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Em JAVA, usando o paradigma orientado a objetos, a solução ficaria conforme descrito a seguir. 
Um arquivo Retangulo.java, contendo todos os atributos e comportamentos esperados em um retân- 
gulo qualquer. 


public class Retangulo 

{ private float altura; 
private float largura; 

public Retangulo() { 
altura = 0; largura = 0; 

} 

public float getAltura() { 
return altura; 

} 

public void setAltura(float a) { 
altura = a; 

} 

public float getLargura() { 
return largura; 

} 

public void setLargura(float 1) { 
largura = 1; 

+ 

public float calculaArea() { 
return altura * largura; 

} 

public float calculaPerimetro() { 
return 2*altura + 2*largura; 


} 
} 


Um arquivo chamado Janela.java, contendo o que se percebeu como necessário para a interface gráfica 
com o usuário. 


import java.io.*; 

import java.util.*; 

class Janela { 
public static void main(String[] args) { 
Retangulo r; 
r = new Retangulo(); 
float altura, largura, area, perimetro; 
Scanner entrada; 
entrada = new Scanner(System.in); 
System.out.print(“Digite o valor da altura do retângulo: “); 
r.setAltura(entrada.nextFloat()); 
System.out.println(“Digite o valor da largura do retângulo: “); 
r.setLargura (entrada.nextFloat()); 
mostraMensagem(“O valor da área é “, r.calculaArea()); 
mostraMensagem(“O valor do perímetro é ”, r.calculaPerimetro()); 
} 
public static void mostraMensagem(String msg, float vlr) { 
System.out.printin(msgtvlr); 


} 
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Cada linguagem de programação atende a pelo menos um paradigma. Alguns autores consideram que 
qualquer paradigma pode ser implementado em qualquer linguagem (inclusive assembly), pois depende 
apenas da forma de pensar do programador e de sua habilidade de programar. De forma inversa, também 
se pode afirmar que o fato de a linguagem dar suporte nativo a determinado paradigma não significa que 
ele foi utilizado. 

Além disso, deve-se observar que o paradigma orientado a objetos não exclui o estruturado, pelo 
contrário, eles trabalham juntos, uma vez que toda a lógica embutida nos objetos segue o pensamento es- 
truturado. 

Por fim, uma observação importantíssima precisa ser feita neste momento: este livro não se destina ao 
estudo da orientação a objetos nem tem a pretensão de discutir vantagens e desvantagens dos diferentes 
paradigmas. Temos como objetivo o desenvolvimento da lógica em programadores iniciantes, junto com a 
utilização das estruturas de controle, das estruturas de dados e dos recursos de modularização disponíveis 
nas linguagens PASCAL, C/C++ e JAVA. Por isso, grande parte das soluções aqui apresentadas segue o 
paradigma estruturado. Nos capítulos finais deste livro, serão abordados alguns conceitos do paradigma 
orientado a objetos. 


CAPÍTULO 


Estrutura 


sequencial 


3.1 Estrutura sequencial em algoritmos 


ALGORITMO 
DECLARE nome da variável tipo da variável 
bloco de comandos 

FIM ALGORITMO. 


3.1.1 Declaração de variáveis em algoritmos 


As variáveis são declaradas após a palavra DECLARE e os tipos mais utilizados são: NUMÉRICO (para vari- 
áveis que receberão números), LITERAL (para variáveis que receberão caracteres) e LÓGICO (para variáveis 
que receberão apenas dois valores: verdadeiro ou falso). 


Exemplo: 


DECLARE X NUMÉRICO 
Y, Z LITERAL 
TESTE LÓGICO 


3.1.2 Comando de atribuição em algoritmos 


O comando de atribuição é utilizado para conceder valores ou operações a variáveis, sendo represen- 
tado pelo símbolo —. 


Exemplo: 


xe 4 

x — X +2 

y — “aula” 
teste — falso 


3.1.3 Comando de entrada em algoritmos 


O comando de entrada é utilizado para receber dados digitados pelo usuário, que serão armazenados 
em variáveis. Esse comando é representado pela palavra LEIA. 


Exemplo: 


LEIA X 


Um valor digitado pelo usuário será armazenado na variável x. 


LEIA Y 


Um ou vários caracteres digitados pelo usuário serão armazenados na variável Y. 
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3.1.4 Comando de saída em algoritmos 


O comando de saída é utilizado para mostrar dados na tela ou na impressora. Esse comando é represen- 
tado pela palavra ESCREVA, e os dados podem ser conteúdos de variáveis ou mensagens. 


Exemplo: 
ESCREVA X 


Mostra o valor armazenado na variável x. 


ESCREVA “Conteúdo de Y = “,Y 


Mostra a mensagem “conteúdo de Y = ” e, em seguida, o valor armazenado na variável y. 
3 , 


3.2 Estrutura sequencial em PASCAL 


PROGRAM nome ; 

USES nomes das unidades; 

VAR nomes das variáveis: tipo; 
BEGIN 

bloco de comandos; 

END. 


As unidades são bibliotecas utilizadas pela linguagem PASCAL para a correta execução do programa. 
A unidade crT é obrigatória em todos os programas, pois faz a adequação do hardware com seu programa. 


3.2.1 Declaração de variáveis em PASCAL 


As variáveis são declaradas após a palavra VAR e os tipos mais utilizados são: INTEGER (para números 
inteiros), REAL (para números reais), CHAR (para um caractere), STRING (para vários caracteres) € BOOLEAN 
(para verdadeiro ou falso). 


Exemplo: 


VAR X: INTEGER; 
Y,Z: REAL; 
NOME: STRING; 
SEXO: CHAR; 
TESTE: BOOLEAN; 


Os identificadores são os nomes das variáveis, dos programas, das constantes, das rotinas e unidades, 
entre outras. 
As regras básicas para a formação dos identificadores são: 


podem ter qualquer tamanho. Entretanto, apenas os 63 primeiros caracteres são utilizados pelo 
compilador; 


os caracteres que podem ser utilizados na formação dos identificadores são: os números, as letras 
maiúsculas, as letras minúsculas e o caractere sublinhado; 


o compilador não faz distinção entre letras maiúsculas e minúsculas, portanto, o identificador NUM 
é exatamente igual ao identificador num; 


o primeiro caractere deve ser sempre uma letra ou o caractere sublinhado; 
não são permitidos espaços em branco e caracteres especiais (8, $, +, -, 3, !1);e 


não é permitido usar palavras reservadas. 
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Palavras reservadas são nomes utilizados pelo compilador para representar comandos, operadores e nomes de 
seções de programas. As palavras reservadas da linguagem PASCAL são: 


and goto program 
asm if record 
array implementation repeat 
begin in set 
case inherited shl 
const inline shr 
constructor interface string 
destructor label then 
div library to 

do mod type 
downto nil unit 
else not until 
end object uses 
exports of var 
file or while 
for packed with 
function procedure xor 


Os tipos de dados mais utilizados na linguagem PASCAL estão descritos na tabela a seguir: 


TIPO FAIXA DE VALORES TAVADHO 
(aproximado) 
shortint —128 a 127 8 bits 
integer —32.768 a 32.767 16 bits 
longint —2.147483.648 a 2.147.483.647 32 bits 
byte 0a 255 8 bits 
word O a 65.535 16 bits 
real 29 x 10% a 1,7 x 10% (11 a 12 dígitos com sinal) 6 bytes 
single 15 x 10-5a 3,4 x 10% (7 a 8 dígitos com sinal) 4 bytes 
double 5,0 x 1032 a 1,7 x 1058 (15 a 16 dígitos com sinal) | 8 bytes 
extended 3,4 x 10923 1,1 x 10%? (19 a 20 dígitos com sinal) | 10 bytes 
comp -9,2 x 108a 9,2 x 108 (19 a 20 dígitos com sinal) 8 bytes 
boolean true ou false 8 bits 
wordbool true ou false 6 bits 
longbool true ou false 32 bits 
bytebool true ou false 8 bits 
char 1 caractere qualquer byte 
string cadeia de caracteres (no máximo 255) tantos bytes quantos forem os caracteres 


3.2.2 Declaração de constantes em PASCAL 


As constantes são declaradas após a palavra CONST e seus valores não podem ser alterados durante a 
execução do programa. 


Exemplo: 


CONST X = 8; 
VE E P 
NOME = 'MARIA"'; 
SEXO = ‘m’; 
TESTE = TRUE; 
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3.2.3 Comando de atribuição em PASCAL 


O comando de atribuição é utilizado para conceder valores ou operações às variáveis, sendo represen- 
tado por := (os sinais de dois pontos e de igualdade). 


Exemplo: 
XxX := 4; 
s RS 54 e AA 
Y Ho Zap 
nome:=' AULA”; 
sexo := 'F'; 
teste := false; 


QQQ Observações 


a) Em PASCAL, os caracteres literais são representados entre apóstrofos. 


b) Os números reais utilizam o ponto como separador decimal. 


c) Cada comando é finalizado com o sinal de ponto e vírgula. 


3.2.4 Comando de entrada em PASCAL 


O comando de entrada é utilizado para receber dados digitados pelo usuário. Esses dados são arma- 
zenados em variáveis. Esse comando é representado pela palavra READIN. Sua sintaxe está representada a 
seguir: 


Sintaxe: 


READLN (nome da variável); 
READLN (nome da variávell,nome da variável2); 


Exemplo: 


READLN(X); 


Um valor digitado pelo usuário será armazenado na variável x. 


READLN (NOME) ; 


Um ou vários caracteres digitados pelo usuário serão armazenados na variável NOME. 
READIN(Y, Z); 


O primeiro valor digitado será armazenado na variável y e o segundo valor será armazenado na vari- 
ável z. Os valores podem ser digitados seguidos de enter ou separados por espaço e finalizados com enter. 


3.2.5 Comando de saída em PASCAL 


O comando de saída é utilizado para mostrar dados na tela ou na impressora. Esse comando é repre- 
sentado pelas palavras WRITE ou WRITELN e os dados podem ser conteúdos de variáveis ou mensagens. 


Sintaxe: 


WRITE (nome da variável); 
WRITELN (nome da variável); 
WRITE ( ‘mensagem’ ); 

WRITELN( ‘mensagem’ ); 

WRITE('mensagem', nome da variável); 
WRITELN('mensagem', nome da variável); 
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Exemplo: 


WRITELN(X) ; 
WRITE(X); 


Mostra o valor armazenado na variável x. 


WRITELN('Conteúdo de Y = ",Y); 
WRITE('Conteúdo de Y = ",Y); 
Mostra a mensagem “conteúdo de Y = ” e em seguida o valor armazenado na variável y. 


A diferença entre esses comandos é que o comando WRITELN mostra seu conteúdo e passa o cursor para 
a linha de baixo, enquanto o comando wRITE mantém o cursor na mesma linha após mostrar a mensagem. 


Exemplo: 

WRITE('aula '); 

WRITE('fácil'); 
Os comandos dados anteriormente geram a saída a seguir: 
aula fácil 

WRITELN( “aula '); 


WRITE('fácil'); 


Os comandos dados anteriormente geram a saída a seguir: 

aula 

fácil 

Nos comandos de saída, é possível ainda fazer a formatação de variáveis do tipo real, single, double, 
extended e comp. Após o nome da variável, coloca-se :m:n, onde m significa a quantidade de espaços da 
tela e n o número de caracteres gastos com a parte fracionária do número. O ponto, que é o separador de- 


cimal, ocupará um caractere do total de caracteres. Os espaços que sobram à esquerda serão preenchidos 
com branco, e, quando faltam espaços, o compilador completa com a necessidade para mostrar o resultado. 


Exemplo: 
WRITE(X:5:2); 
No exemplo anterior, o conteúdo da variável x ocupará 5 espaços na tela. Dois espaços para a parte 
fracionária, um espaço para o ponto e dois espaços para a parte inteira. 
WRITE(X:7:3); 


No exemplo anterior, o conteúdo da variável x ocupará 7 espaços na tela. Três espaços para a parte 
fracionária, um espaço para o ponto e três espaços para a parte inteira. 


3.2.6 Comentários em PASCAL 


Os comentários não são interpretados pelo compilador, servem apenas para esclarecer o programa- 
dor. Constituem excelentes instrumentos de documentação e devem sempre estar entre (........ } ou entre 


3.2.7 Operadores e funções predefinidas em PASCAL 


A linguagem PASCAL possui operadores e funções predefinidas destinados a cálculos matemáticos. 
Alguns são apresentados a seguir. 
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O conteúdo da variável Y é atribuído à variável X (A uma variável pode ser 

= x := y atribuído o conteúdo de outra, um valor constante ou, ainda, o resultado 
de uma função). 

+ x+y Soma o conteúdo de X e de Y. 

= x-y Subtrai o conteúdo de Y do conteúdo de X. 

* x * y Multiplica o conteúdo de X pelo conteúdo de Y. 

/ x/y Obtém o quociente da divisão de X por Y. 

div x div y Obtém o quociente inteiro da divisão de X por Y. 

mod x mod y Obtém o resto da divisão de X por Y. 


a) Os operadores div e mod só podem ser aplicados com operandos do tipo inteiro. 
b) O operador / sempre conduz a um resultado real. 


c) Com os operadores +, —, * e /, se pelo menos um dos operandos for real, então o resultado 
será real. 


Operador Bempo Comemáio 
= Xx=y O conteúdo de X é igual ao conteúdo de Y. 

<> x <> y O conteúdo de X é diferente do conteúdo de Y. 

<= x <= y O conteúdo de X é menor ou igual ao conteúdo de Y. 

>= x >= y O conteúdo de X é maior ou igual ao conteúdo de Y. 

< x< y O conteúdo de X é menor que o conteúdo de Y. 

> x> y O conteúdo de X é maior que o conteúdo de Y. 


abs abs (x) Obtém o valor absoluto de X. 


exp exp(x) Obtém o logaritmo natural e elevado à potência X. 

log log(X) Obtém o logaritmo natural de X. 

trunc trunc(x) Obtém a parte inteira do número real armazenado em X. 
frac frac(x) Obtém a parte fracionária do número real armazenado em X. 


Arredonda X. Para parte fracionária inferior a 0,5, o arredondamento é para baixo. 


Para parte fracionária de 0,5 para cima, o arredondamento é para cima. 
round round (x) 


Exemplo: 

round(1.2) = 1 round(1.5) = 2 round(1.8) = 2 
sin sin(x) Calcula o seno de X (X deve estar representado em radianos). 
cos cos(x) Calcula o cosseno de X (X deve estar representado em radianos). 
pi Pi Retorna o valor de 7. 
sqrt sqrt(x) Calcula a raiz quadrada de X. 
sqr sqr (x) Calcula X elevado ao quadrado. 
inc inc (x,y) Incrementa a variável X com o valor da variável Y. 


dec dec (x,y) Decrementa a variável X com o valor da variável Y. 
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Q Q Q Observação 


Por não existir o operador de potenciação, temos: 
AP = EXP(B*LN(A)) 

Exemplo: 
3º = exp(4*1n(3)) 
51 = exp(10*1n(5)) 


900 Observação 


As funções SIN e cos esperam receber argumentos no formato de radianos; para receber argu- 
mentos em graus, siga o próximo exemplo. Na linguagem PASCAL, não existe uma função para 
tangente; assim, utilize seno/cosseno. 

Exemplo para o cálculo do seno de um ângulo fornecido em graus e utilizando uma variável 
para o valor de m: 


VALORPI := 3.1415; 
READLN(X); { X EM GRAUS ) 
Y := SIN ((VALORPI * X) / 180); 


Exemplo para o cálculo do seno de um ângulo fornecido em graus e utilizando a função pi: 
READLN(X); { X EM GRAUS ) 
Y := SIN ((PI * X) / 180); 


As prioridades entre os operadores são: 


Quando se tem uma expressão em que os operadores possuem a mesma prioridade, a expressão 
é resolvida da esquerda para a direita. 


Exemplos: 
2 +3 4 = 5 4 = 1 
2 * 4/2 = 8/2 = 4 


3.3 Estrutura sequencial em C/C++ 


#include <nome_da_biblioteca> 
int main() 


{ 
bloco de comandos; 
return 0; 


Bibliotecas são arquivos contendo várias funções que podem ser incorporadas aos programas escritos 
em C/C++. A diretiva tinclude faz o texto contido na biblioteca especificada ser inserido no programa. 

A biblioteca stdio.h permite a utilização de diversos comandos de entrada e saída. 

É importante salientar que a linguagem C/C++ é sensível a letras maiúsculas e minúsculas, ou seja, 
considera que letras maiúsculas são diferentes de minúsculas (por exemplo, a é diferente de A). Sendo 
assim, todos os comandos devem, obrigatoriamente, ser escritos com letras minúsculas. 
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3.3.1 Declaração de variáveis em C/C++ 


As variáveis são declaradas após a especificação de seus tipos. Os tipos de dados mais utilizados são: 
int (para números inteiros), float (para números reais) e char (para um caractere). A linguagem C/C++ não 
possui tipo de dados boolean (que pode assumir os valores verdadeiro ou falso), pois considera verdadeiro 
qualquer valor diferente de O (zero). A linguagem C não possui um tipo especial para armazenar cadeias de 
caracteres (strings). Deve-se, quando necessário, utilizar um vetor contendo vários elementos do tipo char. 
Os vetores serão tratados no Capítulo 6. 


Exemplo: 


float X; 


Declara uma variável chamada x em que pode ser armazenado um número real. 


Ro alive TZ 


Declara duas variáveis chamadas Y e z em que podem ser armazenados dois números reais. 


char SEXO; 


Declara uma variável chamada sexo em que pode ser armazenado um caractere. 


char NOME[40]; 


Declara uma variável chamada NomE em que podem ser armazenados até 39 caracteres. O 40º caractere 
será o 0, que indica final da cadeia de caracteres. 

A linguagem C/C++ possui quatro tipos básicos que podem ser utilizados na declaração das variáveis: 
int, float, double e char. À partir desses tipos básicos, podem ser definidos outros, conforme apresentado 
na tabela a seguir. 


Tipo Faixa de valores Tamanho (aproximado) 
char — 128 a 127 8 bits 
unsigned char 0a 255 8 bits 
int —32.768 a 32.767 16 bits 
unsigned int O a 65.535 16 bits 
short int —32.768 a 32.767 16 bits 
long —2.147483.648 a 2.147.483.647 32 bits 
unsigned long O a 4.294.967.295 32 bits 
float 3.4 x 10%8 a 3.4 x 10% 32 bits 
double 1.7 x TOS a 1,7 x 1058 64 bits 
long double 3.4 x 109% a 1.1 x 1092 80 bits 


E importante ressaltar que, de acordo com o processador ou compilador C/C++ utilizado, o tamanho e 
a faixa de valores podem variar. As faixas apresentadas seguem o padrão ANSI e são consideradas mínimas. 


3.3.2 Declaração de constantes em C/C++ 


As constantes são declaradas depois das bibliotecas e seus valores não podem ser alterados durante a 
execução do programa. À declaração de uma constate deve obedecer à seguinte sintaxe: 


#define nome valor 
Exemplo: 


#define x 7 


Define uma constante com identificador x e valor 7. 


#define y 4.5 
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Define uma constante com identificador y e valor 4.5. 


#define nome “MARIA” 


Define uma constante com identificador nome e valor MARIA. 


3.3.3 Comando de atribuição em C/C++ 


O comando de atribuição é utilizado para conceder valores ou operações a variáveis, sendo represen- 
tado por = (sinal de igualdade). 


Exemplo: 
x 4; 
He Es be se MO 
y=2.5; 
sexo = 'F'; 


Caso seja necessário armazenar uma cadeia de caracteres dentro de uma variável, deve-se utilizar uma 
função para manipulação de caracteres, conforme apresentado a seguir: 


strcpy (nome, “João"); 


Para que seja possível a utilização da função strcpy, deve-se inserir no programa, por meio da diretiva 
include, a biblioteca string.h. As funções de manipulação de strings serão abordadas no Capítulo 9. 


QOQ Observações 


Em C/C++, os caracteres são representados entre apóstrofos (* ). As cadeias de caracteres devem 
ser representadas entre aspas ( “ ). 

Em C/C++, cada comando é finalizado com o sinal de ponto e vírgula. 

Em C/C++, a parte inteira e a parte fracionária do número são separadas por um ponto. 


3.3.4 Comando de entrada em C/C++ 


O comando de entrada é utilizado para receber dados digitados pelo usuário. Os dados recebidos são 
armazenados em variáveis. Um dos comandos de entrada mais utilizados na linguagem C/C++ é o scanf. 


Exemplo: 


scanf(“Sd%*c”,&X); 


Um valor inteiro, digitado pelo usuário, será armazenado na variável x. 


scanf (“3Sf3*c”,&Z); 


Um valor real, digitado pelo usuário, será armazenado na variável z. 


scanf (“%s%*c”, &NOME) ; 


Um ou mais caracteres, digitados pelo usuário, serão armazenados na variável NOME. 


scanf(“Sc%*c”,&Y); 


Um caractere, digitado pelo usuário, será armazenado na variável y. 

No comando scanf, é necessário indicar o tipo de variável que será lida: s£ para variáveis que armaze- 
nam números reais; $d para variáveis que armazenam números inteiros; $c para variáveis que armazenam um 
único caractere; e $s para variáveis que armazenam um conjunto de caracteres. 
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O comando scanf armazena em um buffer o conteúdo digitado pelo usuário e armazena também a 
tecla enter utilizada pelo usuário para encerrar a entrada de dados. Para que o buffer seja esvaziado depois 
da atribuição do conteúdo à variável, utiliza-se %*c. 


3.3.5 Comando de saída em C/C++ 


O comando de saída é utilizado para mostrar dados na tela ou na impressora. Um dos comandos de 
saída mais utilizado na linguagem C/C++ é o printf. 


Exemplo: 


printf (”“%d",Y); 


Mostra o número inteiro armazenado na variável Y. 


printf(“Conteúdo de Y = $d”,Y); 


Mostra a mensagem “conteúdo de Y =” e, em seguida, o número inteiro armazenado na variável y. 
, Ed 


printf(“S£”, X); 


Mostra o número real armazenado na variável x. 
printf(“$5.2£", X); 


Mostra o número real armazenado na variável x utilizando cinco caracteres da tela, e, destes, dois 
serão utilizados para a parte fracionária e um para o ponto, que é o separador da parte inteira e da parte 
fracionária. 


printf(“Conteúdo de X = $7.3€f", X); 


Mostra a mensagem “conteúdo de Xx = ” e, em seguida, o número real armazenado na variável x, 
utilizando sete caracteres da tela, e, destes, três serão utilizados para a parte fracionária e um para o ponto, 
que é o separador da parte inteira e da parte fracionária. 

No comando printf é necessário indicar o tipo de variável que será mostrada: %f para variáveis que arma- 
zenam números reais, $d para variáveis que armazenam números inteiros, $c para variáveis que armazenam um 
único caractere, e $s para variáveis que armazenam um conjunto de caracteres. 

No comando printf pode-se utilizar caracteres para posicionar a saída, por exemplo, Yn, que passa o 
cursor para a próxima linha, ou \t, que avança o cursor uma tabulação. 


Exemplo: 

printf(“aula "); 

printf(“fácil”); 
Os comandos dados anteriormente geram a saída a seguir: 
aula fácil 

printf(“aula "); 


printf (“infácil”); 


Os comandos dados anteriormente geram a saída a seguir: 
aula 
fácil 

printf(“aula "); 

printf(“Ntfácil”); 


Os comandos dados anteriormente geram a saída a seguir: 
aula fácil 
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3.3.6 Comentários em C/C++ 


Comentários são textos que podem ser inseridos em programas com o objetivo de documentá-los. Eles 
não são analisados pelo compilador. 

Os comentários podem ocupar uma ou várias linhas, devendo ser inseridos nos programas utilizando- 
-se os símbolos /* ....... */ ou //. 


Exemplo: 
/* 
linhas de comentário 


linhas de comentário 
*/ 


A região de comentários é aberta com os símbolos /* e encerrada com os símbolos */. 
// comentário 
A região de comentários é aberta com os símbolos // e encerrada automaticamente ao final da linha. 


3.3.7 Operadores e funções predefinidas em C/C++ 


A linguagem C/C++ possui operadores e funções predefinidas destinados a cálculos matemáticos. Al- 
guns são apresentados a seguir. 


Operador Exemplo Comentário 

= = O conteúdo da variável Y é atribuído à variável X (A uma variável pode ser atribuído o 
o ERA conteúdo de outra, um valor constante ou, ainda, o resultado de uma função). 
+ x+y Soma o conteúdo de X e de Y. 
= x-y Subtrai o conteúdo de Y do conteúdo de X. 
* x* y Multiplica o conteúdo de X pelo conteúdo de Y. 

Obtém o quociente da divisão de X por Y. 

Se os operandos são inteiros, o resultado da operação será o quociente inteiro da divisão. 
/ / Se os operandos são reais, o resultado da operação será a divisão. 

Y Por exemplo: 

int z = 5/2; — a variável z receberá o valor 2. 

float z = 5.0/2.0; — a variável z receberá o valor 2.5. 
v x 3% y Obtém o resto da divisão de X por Y. 


O operador % só pode ser utilizado com operandos do tipo inteiro. 


Operador Exemplo Comentário 

+= x+=y Equivale a X =X + Y. 

-= x-=y Equivale a X = X — Y. 

+= Xi Equivale a X = X * Y. 

I= x/=y Equivale a X =X / Y. 

%= x%=y Equivale a X = X % Y. 

++ x++ Equivale a X=X+ 1. 

++ y =++x Equivale a X=X + 1 e depois Y = X. 
++ y=x++ Equivale a Y = X e depois X = X +1. 
—— x—— Equivale a X=X- 1. 

—— y=--x Equivale a X = X — 1 e depois Y = X. 
—— y=x-— Equivale a Y = X e depois X=X — 1. 


Os operadores matemáticos de atribuição são utilizados para representar de maneira sintética uma 
operação aritmética e, posteriormente, uma operação de atribuição. Por exemplo, na tabela anterior o ope- 
rador += está sendo usado para realizar a operação x + y e, posteriormente, atribuir o resultado obtido 
à variável x. 


30 | Fundamentos da programação de computadores 


Operador Exemplo Comentário 
== XxX == y O conteúdo de X é igual ao conteúdo de Y. 
l= x l= y O conteúdo de X é diferente do conteúdo de Y. 
<= x <= y O conteúdo de X é menor ou igual ao conteúdo de Y. 
>= x >= O conteúdo de X é maior ou igual ao conteúdo de Y. 
x< y O conteúdo de X é menor que o conteúdo de Y. 
x> y O conteúdo de X é maior que o conteúdo de Y. 
Funções matemáticas 
Função Exemplo Comentário 
i } Arredonda um número real para cima. 
ceil ceil(x) Por exemplo, ceil(3.2) é 4 
cos cos (X) Calcula o cosseno de X (X deve estar representado em radianos). 
exp exp(X) Obtém o logaritmo natural e elevado à potência X. 
abs abs (X) Obtém o valor absoluto de X. 
floor floor (X) Arredonda um número real para baixo. Por exemplo, floor(3.2) é 3 
log log(X) Obtém o logaritmo natural de X 
log10 log10(X) Obtém o logaritmo de base 10 de X 
modf z = modf (X, av) Decompõe o número real armazenado em X em duas partes: 
Y recebe a parte fracionária e z, a parte inteira do número. 
pow pow(X,Y) Calcula a potência de X elevado a Y. 
sin sin(X) Calcula o seno de X (X deve estar representado em radianos). 
sgrt sgrt(X) Calcula a raiz quadrada de X 
tan tan(X) Calcula a tangente de X (X deve estar representado em radianos). 


200 


Observação 


As funções sin, cos e tan esperam receber argumentos no formato de radianos; para recebe- 
rem argumentos em graus, siga o exemplo a seguir. 
Exemplo para o cálculo do seno de um ângulo fornecido em graus e utilizando uma variável para 


o valor de 7q: 
VALORPI = 


Y = 


3.1415; 
scanf(“Sf3*c”,&X); 


//X EM GRAUS 


SIN ((VALORPI * X) / 180); 


A linguagem C/C++ possui muitas outras funções matemáticas que podem ser observadas detalhada- 
mente na documentação da biblioteca math.h. 


Palavras reservadas são nomes utilizados pelo compilador para representar comandos de controle do programa, 
operadores e diretivas. As palavras reservadas da linguagem C/C++ são: 


asm 
class 

do 

export 
goto 
interrupt 
pascal 
_saveregs 
static 


union 


auto 
const 
double 
extern 
huge 
_loadds 
private 
-Seg 
struct 


unsigned 


break case cdecl char 
continue “cs default delete 
“ds else enum _es 

far _fastcall float friend 
for if inline int 

long near new operator 
protected | public register return 
short signed sizeof ss 
switch template this typedef 
virtual void volatile while 
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3.4 Estrutura sequencial em JAVA 


import nome do pacote das classes; 
public class nome 


{ 
public static void main (String args[]) 
{ 
bloco de comandos ; 
> 
} 


Os pacotes de classes são arquivos contendo diferentes classes que possuem vários métodos, ou seja, 
funções, os quais podem ser utilizados nos programas escritos em JAVA. A diretiva import permite que 
o programa reconheça as classes do pacote e, consequentemente, a utilização de seus métodos. 

É importante salientar que a linguagem JAVA é sensível a letras maiúsculas e minúsculas, ou seja, 
considera letras maiúsculas diferentes de minúsculas (por exemplo, a é diferente de A). Sendo assim, cada 
comando tem a própria sintaxe, que, às vezes, é somente com letras minúsculas e outras vezes com letras 
maiúsculas e minúsculas. 


3.4.1 Declaração de variáveis em JAVA 


As variáveis são declaradas após a especificação de seus tipos. Os tipos de dados mais utilizados são: 
int (para números inteiros), float € double (para números reais), char (para um caractere), String (para 
vários caracteres) e boolean (para verdadeiro ou falso). 


Exemplo: 


float X; 


Declara uma variável chamada x em que pode ser armazenado um número real. 


double Y, Z; 


Declara duas variáveis chamadas Y e z em que podem ser armazenados dois números reais. 


char SEXO; 


Declara uma variável chamada sexo em que pode ser armazenado um caractere. 


String NOME; 


Declara uma variável chamada NoME em que podem ser armazenados vários caracteres. 


A linguagem JAVA possui os tipos primitivos de dados listados a seguir. 


Tipo Faixa de valores Tamanho (aproximado) 
byte — 128 a 127 8 bits 
char O a 65.535 16 bits 
short —32.768 a 32.767 16 bits 
int —2.147.483.648 a 2.147.483.647 32 bits 
long —9.223.372.036.854.775.808 a 64 bits 
9.223.372.036.854.775.807 
float —3.4 x 1078 a 3.4 x 10% 32 bits 
double —1.7 x 1078 a 1.7 x 10% 64 bits 


boolean true ou false indefinido 
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3.4.2 Declaração de constantes em JAVA 


Constantes em JAVA podem ser declaradas em diferentes locais e isso define o seu escopo. Por escopo, 
pode-se entender as partes de um programa em que uma constante e também variáveis são compreendidas e 
podem ser utilizadas, sem acarretar erros de compilação. Sendo assim, se a constante for declarada fora de 
qualquer método (por exemplo, o main), ela terá escopo mais abrangente e poderá ser utilizada em qualquer 
ponto da classe. Se a constante for declarada dentro de um método, seu escopo ficará restrito a esse método. 

A declaração de uma constante deve obedecer à seguinte sintaxe: 

final tipo da constante nome da constante = valor da constante; 


Exemplo: 
final int X = 8; 
Declaração da constante X, que é do tipo int, com valor 8. 


final String NOME = “MARIA”; 


Declaração da constante NOME, que é do tipo String, com valor MARIA. 
3.4.3 Comando de atribuição em JAVA 


O comando de atribuição é utilizado para conceder valores ou operações às variáveis, sendo represen- 
tado por = (sinal de igualdade). 


Exemplo: 
na es tita 
x He ap DE 
W E 2950 
sexo = 'F'; 


900 Observações 


Em JAVA, os caracteres são representados entre apóstrofos (* ). As cadeias de caracteres devem 
ser representadas entre aspas ( “). 

Nessa linguagem, cada comando é finalizado com o sinal de ponto e vírgula. 

Em JAVA, os números reais tem a parte inteira separada da parte fracionária por um ponto. 


3.4.4 Comando de entrada em JAVA 


O comando de entrada é utilizado para receber dados digitados pelo usuário. Os dados recebidos são 
armazenados em variáveis. Uma das formas de entrada utilizada na linguagem JAVA é por meio da classe 
Scanner, que requer a importação do pacote java.util. 


Exemplos: 


int nl; 

Scanner dado; 

dado = new Scanner (System. in); 
nl = dado.nextInt(); 


Um valor inteiro digitado pelo usuário será armazenado na variável n1. 


float x; 

Scanner dado; 

dado = new Scanner (System. in); 
x = dado.nextFloat(); 


Um valor real digitado pelo usuário será armazenado na variável x. 
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String nome; 

Scanner dado; 

dado = new Scanner (System. in); 
nome = dado.next(); 


Um valor literal digitado pelo usuário será armazenado na variável nome. 

É importante salientar que todas as entradas são recebidas pela linguagem JAVA como um conjunto 
de caracteres. Assim, esses caracteres deverão ser convertidos por funções de conversão de tipos. Seguem 
algumas dessas funções. 


Função Funcionalidade 
nex Aguarda uma entrada em formato String com uma única palavra. 
nextLine() Aguarda uma entrada em formato String com uma ou várias palavras. 
nextint) Aguarda uma entrada em formato inteiro. 
nextByte() Aguarda uma entrada em formato inteiro. 
nextLong() Aguarda uma entrada em formato inteiro. 
nextFloat() Aguarda uma entrada em formato número fracionário. 
nextDouble() Aguarda uma entrada em formato número fracionário. 


O tratamento de cadeia de caracteres será mais detalhado no Capítulo 9. 


3.4.5 Comando de saída em JAVA 


O comando de saída é utilizado para mostrar dados na tela ou na impressora. Os comandos de saída 
mais utilizados na linguagem JAVA são System.out.println e System.out.print. 


Exemplo: 


System.out.printlin(X); 


Mostra o valor armazenado na variável x. 


System.out.println(“Conteúdo de X =" + X); 


Mostra a mensagem “conteúdo de x =” e, em seguida, o valor armazenado na variável x. 

A diferença entre esses comandos é que o comando System.out.printIn mostra seu conteúdo e passa 
o cursor para a linha de baixo, enquanto o comando System.out.print mantém o cursor na mesma linha 
após mostrar a mensagem. 


Exemplo: 


System.out.print(“aula “); 
System.out.print (“fácil”); 


Os comandos dados anteriormente geram a saída a seguir: 
aula fácil 


System.out.println(“aula “); 
System.out.println(“fácil”); 


Os comandos dados anteriormente geram a saída a seguir: 
aula 
fácil 


3.4.6 Comentários em JAVA 


Comentários são textos que podem ser inseridos em programas com o objetivo de documentá-los. Eles 
são ignorados pelo interpretador. 

Os comentários podem ocupar uma ou várias linhas, devendo ser inseridos nos programas utilizando- 
-se os símbolos /* ....... */ ou //. 
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Exemplo: 
/* 
linhas de comentário 


linhas de comentário 


*/ 
A região de comentários é aberta com os símbolos /* e encerrada com os símbolos */. 
// comentário 
A região de comentários é aberta com os símbolos // e encerrada automaticamente ao final da linha. 


3.4.7 Operadores e funções predefinidas em JAVA 


A linguagem JAVA possui operadores e funções predefinidas destinados a cálculos matemáticos. Alguns 
são apresentados a seguir. 


Operador Exemplo Comentário 


O conteúdo da variável Y é atribuído à variável X (A uma variável pode ser atribuído o 


= ERE, conteúdo de outra variável, um valor constante ou, ainda, o resultado de uma função). 
+ Xx+ Y Soma o conteúdo de X e de Y. 
— x-y Subtrai o conteúdo de Y do conteúdo de X. 
* x* y Multiplica o conteúdo de X pelo conteúdo de Y. 
Obtém o quociente da divisão de X por Y. 
Se os operandos são inteiros, o resultado da operação será o quociente inteiro da divisão. 
Se os operandos são reais, o resultado da operação será a divisão. 
/ x/y P . 
or exemplo: 
int z = 5/2; — a variável z receberá o valor 2. 
double z = 5.0/2.0; — a variável z receberá o valor 2.5. 
v x 3% y Obtém o resto da divisão de X por Y. 
+= x += y | Equivale a X = X + Y. 
-= x —= y | Equivale a X = X — Y. 
*= x *= y | Equivale a X = X * Y. 
/= x /= y | Equivale aX = X/Y. 
$= x %= y | Equivale a X = X % Y. 
spas X++ Equivale a X = X + 1. 
++ y = ++x | Equivale a X = X + 1 e depois Y = X. 
++ y = x++ Equivale a Y = X e depois X = X +1. 
—— X—— Equivale a X = X — 1. 
EE y = ——x | Equivale a X = X — 1 e depois Y = X. 
—— y = x—— | Equivale a Y = X e depois X = X — 1. 


Os operadores matemáticos de atribuição são utilizados para representar, de maneira sintética, uma ope- 
ração aritmética e, posteriormente, uma operação de atribuição. Por exemplo, na tabela anterior, o operador 
+= está sendo usado para realizar a operação x + y e, posteriormente, atribuir o resultado obtido à variável x. 


Operador Exemplo Comentário 
== x == y O conteúdo de X é igual ao conteúdo de Y. 
l= x l= y O conteúdo de X é diferente do conteúdo de Y. 
<= x <= y O conteúdo de X é menor ou igual ao conteúdo de Y. 
>= x >= y O conteúdo de X é maior ou igual ao conteúdo de Y. 
< x< y O conteúdo de X é menor que o conteúdo de Y. 
> x> y O conteúdo de X é maior que o conteúdo de Y. 
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Funções matemáticas 


Função Exemplo Comentário 
ceil Math.ceil(X) Arredonda um número real para cima. Por exemplo, ceil(3.2) é 4 
cos Math.cos(X) Calcula o cosseno de X (X deve estar representado em radianos). 
exp Math.exp(X) Obtém o logaritmo natural e elevado à potência X 
abs Math.abs(X) Obtém o valor absoluto de X 
floor Math.floor (X) Arredonda um número real para baixo. Por exemplo, floor(3.2) é 3 
log Math.log(X) Obtém o logaritmo natural de X. 
log10 Math.log10(X) Obtém o logaritmo de base 10 de X 
pow Math.pow(X,Y) Calcula a potência de X elevado a Y. 
sin Math.sin(X) Calcula o seno de X (X deve estar representado em radianos). 
sgrt Math.sgrt(X) Calcula a raiz quadrada de X 
cbrt Math.cbrt(X) Calcula a raiz cúbica de X. 
tan Math.tan(X) Calcula a tangente de X (X deve estar representado em radianos). 
PI Math.PI Retorna o valor de x 
toDegrees |Math.toDegrees(X) | Converte a medida de X de radianos para graus. 
toRadians  'Math.toRadians(X) Converte a medida de X de graus para radianos 


RIOS) Observação 


Os métodos sin, cos e tan esperam receber argumentos no formato de radianos; para receberem 
argumentos em graus, siga o próximo exemplo. 


dado = new Scanner(System.in); 
x = dado.nextDouble(); 
y = Math.sin(Math.toRadians(x)); 


A linguagem JAVA possui muitas outras funções matemáticas que podem ser observadas detalhada- 
mente na documentação da classe Math. 


Palavras reservadas são nomes utilizados pela linguagem para representar comandos de controle do programa, 
operadores e diretivas. 


abstract continue for new switch 
assert default if package synchronized 
boolean do goto private this 

break double implements protected throw 

byte else import public throws 

case enum instanceof return transient 
catch extends int short try 

char final interface static void 

class finally long strictfp volatile 
const float native super while 


Tem-se ainda em JAVA os literais reservados e que, assim como as palavras reservadas, não podem ser 
usados como identificadores, pois apresentarão erro de compilação. São eles: nu11, true e false. 
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EXERCÍCIOS RESOLVIDOS 


BEER Faça um programa que receba quatro números inteiros, calcule e mostre a soma desses números. 
(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE nl, n2, n3, n4, soma NUMÉRICO 
LEIA nl, n2, n3, n4 
soma + nl + n2 + n3 + n4 
ESCREVA soma 
FIM ALGORITMO. 


PASCAL 12 soLUÇÃO: 
CD \EXERC\CAP3\PASCAL\EX1_A.PAS e \EXERC\CAP3\PASCAL\EX1_A. EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\PASCAL\EX1_B.PAS e \EXERC\CAP3\PASCAL\EX1_B.EXE 


C/C++ 1º soLução: 
CED \EXERC\CAP3\C++\EX1_A.CPP e \EXERC\CAP3\C++\EX1_A.EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\C++\EX1_B.CPP e \EXERC\CAP3\C++\EX1_B.EXE 


JAVA 12 soLuçÃO: 
EEE: NEXERCACAP3NJAVANEXI A.java e \EXERC\CAP3\JAVA\EX1_A.class 


22 SOLUÇÃO: 


NEXERCACAP3NJAVANEXI B.java e VEXERCICAP3NJAVANEX1I BA.class 


IFJ Faça um programa que receba três notas, calcule e mostre a média aritmética. 
(ALLISIoIRL ITIMO) 12 sorução: 


ALGORITMO 
DECLARE notal, nota2, nota3, media NUMÉRICO 
LEIA notal, nota2, nota3 
media <— (notal + nota2 + nota3)/3 
ESCREVA media 
FIM ALGORITMO. 


22 SOLUÇÃO: 


ALGORITMO 
DECLARE notal, nota2, nota3, soma, media NUMÉRICO 
LEIA notal, nota2, nota3 
soma — notal + nota2 + nota3 
media + soma/3 
ESCREVA media 
FIM ALGORITMO. 


PASCAL 12 soLUÇÃO: 
cD \EXERC\CAP3\PASCAL\EX2_A.PAS e \EXERC\CAP3\PASCAL\EX2_A. EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\PASCAL\EX2_B.PAS e \EXERC\CAP3\PASCAL\EX2_B. EXE 
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Quando estamos trabalhando com tipos de dados reais, precisamos fazer a formatação desses números. 
Se isso não for feito, eles serão apresentados com formatação científica. 


Exemplo de números com formatação científica: 


1.5000000000E+04 
7.0000000000E+00 


15000 
7 


Exemplo de formatação: 


x:6:2 A variável x será mostrada com seis caracteres: dois caracteres para a parte fracionária, um carac- 
tere para o ponto e os outros três caracteres restantes para a parte inteira. 


y:8:3 A variável Y será mostrada com oito caracteres: três caracteres para a parte fracionária, um 
caractere para o ponto e os outros quatro caracteres restantes para a parte inteira. 
Variável: número total de caracteres: número de caracteres da parte fracionária 


O primeiro parâmetro da formatação corresponde ao número total de caracteres mostrados na tela; o 


segundo, ao total de caracteres ocupados pela parte fracionária. O ponto, que é o separador entre a parte 
inteira e fracionária, também ocupa um caractere. 


Os caracteres à direita serão preenchidos com zeros e os caracteres à esquerda serão preenchidos com 
espaços em branco. 


32 SOLUÇÃO: 


NEXERCICAP3NPASCALNEX2 C.PAS e \EXERC\CAP3\PASCAL\EX2_C. EXE 


PLETT 1º soLução: 
Eae \EXERC\CAP3\C++\EX2_A.CPP e NEXERCICAP3ICHEX2 A. EXE 


Quando estamos trabalhando com tipos de dados reais, precisamos fazer a formatação desses números 
para definir quantas casas decimais devem ser mostradas. Assim, no comando de saída printf, a formata- 
ção é especificada imediatamente antes da letra que define o tipo da variável que será mostrada. 


Exemplo: 


printf(“Conteúdo de variável X é: 3%6.3f",X); 


No comando dado anteriormente, $£ especifica que será mostrado um número real, e 6.3 significa que 
serão utilizados seis caracteres para mostrar o número, e, destes, três caracteres para a parte fracionária, um 
caractere para o ponto e os outros dois caracteres restantes para a parte inteira. 

22 SOLUÇÃO: 
NEXERCACAP3ACA 


-+VEX2 B.CPP e \EXERC\CAP3\C++\EX2_B. EXE 
32 SOLUÇÃO: 
NEXERCACAP3NCA 


+\EX2_C.CPP e \EXERC\CAP3\C++\EX2_C. EXE 


BAQIMAN 1º soLução: 
CEED \EXERC\CAP3\JAVA\EX2_A.java e \EXERC\CAP3\JAVA\EX2_A.class 


Quando estamos trabalhando com tipos de dados reais, precisamos fazer a formatação desses números 
para definir a quantidade de casas decimais que devem ser mostradas. 


Deve-se utilizar o método DecimalFormat, conforme apresentado a seguir: 


DecimalFormat casas; 
casas = new DecimalFormat(“0.00”); 
System.out.println(“Média = "+casas. format (media) ); 


No exemplo anterior, a formatação permitirá que sejam mostradas duas casas decimais para o valor da 


variável média. Para a utilização do método DecimalFormat, deve-se incluir o pacote de classes text, ou 
seja, import java.text.*; 
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22 SOLUÇÃO: 
VEXERCACAP3NJAVANEX2 B.java e NEXERCICAP3NJAVANEX2 B.class 
32 soLUÇÃO: 


NEXERCICAP3NJAVANEX2 C.java e VEXERCÍCAP3NJAVANEX2 C.class 


IEA Faça um programa que receba três notas e seus respectivos pesos, calcule e mostre a média ponderada. 


(ALLISIoIRL ITIMO) 12 sorução: 


ALGORITMO 
DECLARE notal, nota2, nota3, pesol, peso2, peso3, media NUMÉRICO 
LEIA notal, nota2, nota3, pesol, peso2, peso3 
media< (notal*pesol-nota2*peso2-nota3*peso3)/(pesol---peso2-+-peso3) 
ESCREVA media 

FIM ALGORITMO. 


22 SOLUÇÃO: 


ALGORITMO 
DECLARE notal, nota2, nota3, pesol, peso2, peso3 NUMÉRICO 
somal, soma2, soma3, total, media NUMÉRICO 
LEIA notal, nota2, nota3, pesol, peso2, peso3 
somal < notal * pesol 
soma? < nota? * peso2 
soma3 < nota3 * peso3 
total < pesol + peso2 + peso3 


media (somal + soma2 + soma3)/total 
ESCREVA media 
FIM ALGORITMO. 


PASCAL [Sono tos 
C \EXERC\CAP3\PASCAL\EX3_A.PAS e \EXERC\CAP3\PASCAL\EX3_A.EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\PASCAL\EX3_B.PAS e \EXERC\CAP3\PASCAL\EX3_B.EXE 


32 SOLUÇÃO: 
\EXERC\CAP3\PASCAL\EX3_C.PAS e \EXERC\CAP3\PASCAL\EX3_C.EXE 


C/C++ 1º soLução: 
ed) NEXERCNCAP3NC- HNEX3 A.CPP e NEXERCICAP3ACIHHNEX3 A.EXE 


2º SOLUÇÃO: 
\EXERC\CAP3\C++\EX3_B.CPP e \EXERC\CAP3\C++\EX3_B.EXE 


32 SOLUÇÃO: 


VEXERCACAP3AC++HNEX3 C.CPP e \EXERC\CAP3\C++\EX3_C. EXE 


JAVA 12 soLuçãÃo: 
(Es VEXERCACAP3NJAVANEX3 A.java e VEXERCICAP3NJAVANEX3 A.class 


22 SOLUÇÃO: 


NEXERCACAP3NJAVANEX3 B.java e VEXERCICAP3NJAVANEX3 B.class 


32 SOLUÇÃO: 
NEXERCACAP3NJAVANEX3 C.java e VEXERCICAP3NJAVANEX3 C.class 
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EA Faça um programa que receba o salário de um funcionário, calcule e mostre o novo salário, sabendo-se 
que este sofreu um aumento de 25%. 


[ALLIGIOJRILITIMIO) 12 sorução: 


ALGORITMO 
DECLARE sal, novosal NUMÉRICO 
LEIA sal 
novosal < sal + sal * 25/100 
ESCREVA novosal 

FIM ALGORITMO. 


22 SOLUÇÃO: 


ALGORITMO 
DECLARE sal, aumento, novosal NUMÉRICO 
LEIA sal 
aumento + sal * 25/100 
novosal + sal + aumento 
ESCREVA novosal 
FIM ALGORITMO. 


PASCAL 12 SoLUÇÃO: 
(Z \EXERC\CAP3\PASCAL\EX4_A.PAS e \EXERC\CAP3\PASCAL\EX4_A. EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\PASCAL\EX4_B.PAS e \EXERC\CAP3\PASCAL\EX4_B.EXE 


c/c++ 12 solução: 
Z] \EXERC\CAP3\C++\EX4_A.CPP e \EXERC\CAP3\C++\EX4_A.EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\C++\EX4_B.CPP e \EXERC\CAP3\C++\EX4_B.EXE 


BAIANO 1º soLução: 
(C VEXERCNCAP3NJAVANEX4 A.java e VEXERCYCAP3NJAVAVEX4 A.class 


22 SOLUÇÃO: 
NEXERCACAP3NJAVANEX4 B.java e VEXERCÍCAP3NJAVANEX4 B.class 


EA Faça um programa que receba o salário de um funcionário e o percentual de aumento, calcule e mostre 
o valor do aumento e o novo salário. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE sal, perc, aumento, novosal NUMÉRICO 
LEIA sal, perc 
aumento < sal * perc/100 
ESCREVA aumento 
novosal +— sal + aumento 
ESCREVA novosal 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
VEXERCACAP3NPASCALVEX5.PAS e NEXERCACAP3NPASCALNEX5. EXE 


fe) forma SoLução: 
D 
\EXERC\CAP3\C++\EX5.CPP e \EXERC\CAP3\C++\EX5 . EXE 
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JAva SOLUÇÃO: 
GERE 


VEXERCACAP3AJAVANEX5. java e \EXERC\CAP3\JAVA\EX5.class 


EA Faça um programa que receba o salário base de um funcionário, calcule e mostre o salário a receber, 


sabendo-se que o funcionário tem gratificação de 5% sobre o salário base e paga imposto de 7% tam- 
bém sobre o salário base. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE sal, salreceber, grat, imp NUMÉRICO 
LEIA sal 
grat <— sal * 5/100 
imp + sal * 7/100 
salreceber < sal + grat imp 
ESCREVA salreceber 
FIM ALGORITMO. 


PASCAL SoLUÇÃO: 
EE 


VEXERCACAP3NPASCALVEX6.PAS e NEXERCACAP3NPASCALNEX6.EXE 


AVETS SoLução: 
Es 


\EXERC\CAP3\C++\EX6.CPP e \EXERC\CAP3\C++\EX6.EXE 


BAIANA SoLução: 
VEXERCACAP3AJAVANEX6. java e \EXERC\CAP3\JAVA\EX6.class 


IEA Faça um programa que receba o salário base de um funcionário, calcule e mostre seu salário a receber, 
sabendo-se que o funcionário tem gratificação de R$ 50 e paga imposto de 10% sobre o salário base. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE sal, salreceber, imp NUMÉRICO 
LEIA sal 
imp 4 sal * 10/100 
salreceber < sal + 50 imp 


ESCREVA salreceber 
FIM ALGORITMO. 


PASCAL SoLUÇÃO: 


\EXERC\CAP3\PASCAL\EX7.PAS e NEXERCACAP3NPASCALNEX7.EXE 


Lon Ta SoLução: 
m \EXERC\CAP3\C++\EX7.CPP e \EXERC\CAP3\C++\EX7.EXE 
E-GO SoLução: 


cD \EXERC\CAP3\JAVA\EX7.java e \EXERC\CAP3\JAVA\EX7.class 


EJ Faça um programa que receba o valor de um depósito e o valor da taxa de juros, calcule e mostre o 
valor do rendimento e o valor total depois do rendimento. 


(ALLISIOJELITIMO) Solução: 


ALGORITMO 


DECLARE dep, taxa, rend, total NUMÉRICO 
LEIA dep, taxa 
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rend + dep * taxa/100 
total + dep + rend 
ESCREVA rend 
ESCREVA total 

FIM ALGORITMO. 


PINNA SoLUÇÃO: 
CHEES 
\EXERC\CAP3\PASCAL\EX8.PAS e VEXERCACAP3NPASCALNEX8.EXE 


VETIA Solução: 
GEES 
\EXERC\CAP3\C++\EX8.CPP e \EXERC\CAP3\C++\EX8.EXE 


RB LWIA NA SoLução: 


NEXERCICAP3AJAVAlEX8. java e \EXERC\CAP3\JAVA\EX8.class 


HEM Faça um programa que calcule e mostre a área de um triângulo. Sabe-se que: Área = (base * altura)/2. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE base, altura, area NUMÉRICO 
LEIA base, altura 
area + (base * altura)/2 
ESCREVA area 
FIM ALGORITMO. 


PASCAL [Sono 
[Pt 
\EXERC\CAP3\PASCAL\EX9.PAS e NEXERCACAP3NPASCALNEX9. EXE 


c/c++ Solução: 
GEES 
\EXERC\CAP3\C++\EX9.CPP e VEXERCACAP3NC++HNEX9 . EXE 


RB WIANA SoLução: 


\EXERC\CAP3\JAVA\EX9.java e VEXERCICAP3AJAVANEX9.class 


ELA Faça um programa que calcule e mostre a área de um círculo. Sabe-se que: Área = m * R2. 


(AILTGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE area, raio NUMÉRICO 
LEIA raio 
area <— 3.1415 * raio” 
ESCREVA area 

FIM ALGORITMO. 


PASCAL 12 soLUÇÃO: 
CED \EXERC\CAP3\PASCAL\EX10_A.PAS e \EXERC\CAP3\PASCAL\EX10_A.EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\PASCAL\EX10_B.PAS e \EXERC\CAP3\PASCAL\EX10_B.EXE 
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32 soLUÇÃO: 
NEXERCICAP3NPASCALNEX10 C.PAS e NEXERCICAP3NPASCALNEX1IO C.EXE 


Esse programa usou algumas funções predefinidas da linguagem PASCAL que estão descritas na Seção 3.2.7. 


VLS Ram 1º soLução: 
D \EXERC\CAP3\C++\EX10_A.CPP e \EXERC\CAP3\C++\EX10_A.EXE 


22 SOLUÇÃO: 
\EXERC\CAP3\C++\EX10_B.CPP e \EXERC\CAP3\C++\EX10_B.EXE 


Esse programa usou algumas funções predefinidas da linguagem C/C++ que estão descritas na Seção 3.3.7. 


JAVA A l? soLuçãÃo: 
D \EXERC\CAP3\JAVA\EX10_A.java e \EXERC\CAP3\JAVA\EX10_A.class 


22 SOLUÇÃO: 
\EXERC\CAP3\JAVA\EX10_B.java e \EXERC\CAP3\JAVA\EX10_B.class 


Esse programa usou alguns métodos da linguagem JAVA que estão descritos na Seção 3.4.7. 


EIN Faça um programa que receba um número positivo e maior que zero, calcule e mostre: 


a) o número digitado ao quadrado; 
b) 
c) a raiz quadrada do número digitado; 
d) a raiz cúbica do número digitado. 


o número digitado ao cubo; 


(AILTGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE num, quad, cubo, r2, r3 NUMÉRICO 
LEIA num 
quad < num 


cubo — num 
2 
r2 + Nnum 


<i 
r3 — NVnum 


ESCREVA quad, cubo, r2, r3 
FIM ALGORITMO. 


PASCAL [NSioNio:tor 
[= 4] 
VEXERCACAP3NPASCALVEX11.PAS e NEXERCACAP3NPASCALNEX11.EXE 


Esse programa usou algumas funções predefinidas da linguagem PASCAL que estão descritas na Seção 3.2.7. 


C/c++ ENNIO 
Cc 
\EXERC\CAP3\C++\EX11.CPP e NEXERCACAP3AC++NEX11.EXE 


Esse programa usou algumas funções predefinidas da linguagem C/C++ que estão descritas na Seção 3.3.7. 


JAVA SOLUÇÃO: 
o \EXERC\CAP3\JAVA\EX11.java e \EXERC\CAP3\JAVA\EX11.class 


Esse programa usou alguns métodos da linguagem JAVA que estão descritos na Seção 3.4.7. 


Capítulo 3 Estrutura sequencial | 43 


EPA Faça um programa que receba dois números maiores que zero, calcule e mostre um elevado ao outro. 
(AJLIGIOJRN ITIM(O) SoLução: 


ALGORITMO 
DECLARE numl, num2, rl, r2 NUMÉRICO 
LEIA numl, num2 
wi <= sont beta 
162) = jobim 
ESCREVA rl, r2 
FIM_ALGORITMO. 


PASCAL SoLUÇÃO: 
GEES 


VEXERCICAP3NPASCALVEX12.PAS e VEXERCACAP3NPASCALNEX12.EXE 


Esse programa usou algumas funções predefinidas da linguagem PASCAL que estão descritas na Seção 3.2.7. 


eylen Ra SoLução: 
GE 


\EXERC\CAP3\C++\EX12.CPP e NEXERCACAP3AC++NEX12.EXE 


Esse programa usou algumas funções predefinidas da linguagem C/C++ que estão descritas na Seção 3.3.7. 


RB WIAN SoLução: 
GEN 


\EXERC\CAP3\JAVA\EX12.java e VEXERCICAP3AJAVANEX12.class 


Esse programa usou alguns métodos da linguagem JAVA que estão descritos na Seção 3.4.7. 


EEA Sabe-se que: 
pé = 12 polegadas 
1 jarda = 3 pés 
1 milha = 1,760 jarda 
Faça um programa que receba uma medida em pés, faça as conversões a seguir e mostre os resultados. 
a) polegadas; 
b) jardas; 
c) milhas. 


(AILTGJOJRI ITIM]O) SoLução: 


ALGORITMO 
DECLARE pes, polegadas, jardas, milhas NUMÉRICO 
LEIA pes 
polegadas + pes * 12 
jardas + pes / 3 
milhas + jardas / 1760 
ESCREVA polegadas, jardas, milhas 
FIM ALGORITMO. 


PASCAL SoLUÇÃO: 
Es 
\EXERC\CAP3\PASCAL\EX13.PAS e VEXERCICAP3NPASCALNEX13.EXE 


C/c++ ERR 
Gu 
\EXERC\CAP3\C++\EX13.CPP e NEXERCACAP3AC++NEX13.EXE 


BAIA SoLução: 


\EXERC\CAP3\JAVA\EX13.java e VEXERCICAP3AJAVANEX13.class 
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ELA Faça um programa que receba o ano de nascimento de uma pessoa e o ano atual, calcule e mostre: 
a) a idade dessa pessoa; 
b) quantos anos ela terá em 2050. 


(ALLISIOJEL INTIMO) Solução: 


ALGORITMO 
DECLARE ano atual, ano nascimento, idade atual, idade 2050 NUMÉRICO 
LEIA ano atual 
LEIA ano nascimento 
idade atual + ano atual — ano nascimento 
idade 2050 + 2050 — ano nascimento 
ESCREVA idade atual 
ESCREVA idade 2050 
FIM ALGORITMO. 


PINNA SoLUÇÃO: 
D 


\EXERC\CAP3\PASCAL\EX14.PAS e \EXERC\CAP3\PASCAL\EX14.EXE 


ylen Ra SoLuçÃo: 
Eoo 


\EXERC\CAP3\C++\EX14.CPP e \EXERC\CAP3\C++\EX14.EXE 


REGIS SoLução: 
CEE 


VEXERCACAP3AJAVAlEX14. java e \EXERC\CAP3\JAVA\EX14.class 


H O custo ao consumidor de um carro novo é a soma do preço de fábrica com o percentual de lucro do 
distribuidor e dos impostos aplicados ao preço de fábrica. Faça um programa que receba o preço de fá- 
brica de um veículo, o percentual de lucro do distribuidor e o percentual de impostos, calcule e mostre: 
a) o valor correspondente ao lucro do distribuidor; 

b) o valor correspondente aos impostos; 
c) o preço final do veículo. 


(AILTGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE p fab, perc d, perc i, vlr d, vlr i, p final NUMÉRICO 
LEIA p fab 
LEIA perc d 
LEIA perc i 
vlr d +— p fab * perc d / 100 
vlr i — p fab * perc i / 100 
pirina = fo atelo) ap dio (el qr vb al 
ESCREVA vlr d 
ESCREVA vlr i 
ESCREVA p final 

FIM ALGORITMO. 


PASCAL SoLUÇÃO: 
\EXERC\CAP3\PASCAL\EX15.PAS e NEXERCACAP3NPASCALNEX15.EXE 


eylen Ra Sorução: 


\EXERC\CAP3\C++\EX15.CPP e NEXERCACAP3AC++NEX15. EXE 
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RANMA SoLução: 
Gs 


\EXERC\CAP3\JAVA\EX15.java e VEXERCICAP3AJAVANEX15.class 


HA Faça um programa que receba o número de horas trabalhadas e o valor do salário mínimo, calcule e 
mostre o salário a receber, seguindo estas regras: 
a) a hora trabalhada vale a metade do salário mínimo. 
b) 
c) o imposto equivale a 3% do salário bruto. 
) 


d 
(AILTGIOJRILITIM]O) SoLução: 


o salário bruto equivale ao número de horas trabalhadas multiplicado pelo valor da hora trabalhada. 


o salário a receber equivale ao salário bruto menos o imposto. 


ALGORITMO 
DECLARE horas t, vlr sal min, vlr hora t NUMÉRICO 
vlr sal bru, imp, vlr sal liq NUMÉRICO 
LEIA horas t 
LEIA vlr sal min 
vlr hora t <— vlr sal min / 2 
vlr sal bru + vlr hora t * horas t 
imp — vlr sal bru * 3 / 100 
vlr sal lig < vlr sal bru — imp 
ESCREVA vlr sal lig 
FIM ALGORITMO. 


PINNA SOLUÇÃO: 
GE 
NEXERCACAP3NPASCALVEX16.PAS e VEXERCICAP3NPASCALNEX16.EXE 


eylen Ra SoLução: 


\EXERC\CAP3\C++\EX16.CPP e NEXERCACAP3AC++NEX16.EXE 


RANMA SoLução: 
GRE 


\EXERC\CAP3\JAVA\EX16.java e NEXERCICAP3iJAVANEX16.class 


EFA Um trabalhador recebeu seu salário e o depositou em sua conta bancária. Esse trabalhador emitiu dois 
cheques e agora deseja saber seu saldo atual. Sabe-se que cada operação bancária de retirada paga 
CPMF de 0,38% e o saldo inicial da conta está zerado. 


(AILTGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE salario, chequel, cheque2, cpmfl, cpmf2, saldo NUMÉRICO 
LEIA salario 
LEIA chequel 
LEIA cheque? 
cpmfl <- chequel * 0.38 / 100 
cpmf2 < cheque? * 0.38 / 100 
saldo + salario — chequel — cheque? — cpmfl — cpmf2 
ESCREVA saldo 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
GER 
VEXERCACAP3NPASCALVEX17.PAS e NVEXERCACAP3NPASCALNEX17.EXE 
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C/c++ ENIO 
GE 


\EXERC\CAP3\C++\EX17.CPP e NEXERCACAP3AC++NEX17.EXE 


E-Go- SoLução: 
Es 


\EXERC\CAP3\JAVA\EX17.java e NEXERCICAP3AJAVANEX17.class 


EEJ Pedro comprou um saco de ração com peso em quilos. Ele possui dois gatos, para os quais fornece a 
quantidade de ração em gramas. À quantidade diária de ração fornecida para cada gato é sempre a 
mesma. Faça um programa que receba o peso do saco de ração e a quantidade de ração fornecida para 
cada gato, calcule e mostre quanto restará de ração no saco após cinco dias. 


(ALLISIOJELITIMO) Solução: 


ALGORITMO 
DECLARE peso saco, racao gatol, racao gato2, total final NUMÉRICO 
LEIA peso saco 
LEIA racao gatol 
LEIA racao gato2 
racao gatol <- racao gatol / 1000 
racao gato2 < racao gato2 / 1000 
total final < peso saco — 5 * (racao gatol + racao gato2) 
ESCREVA total final 
FIM ALGORITMO. 


PINNA SoLUÇÃO: 
GHEER 


VEXERCACAP3APASCALVEX18.PAS e VEXERCICAP3NPASCALNEX18.EXE 


C/C++ Sorução: 
Gia 


\EXERC\CAP3\C++\EX18.CPP e NEXERCACAP3AC++NEX18.EXE 


RANMA SoLução: 
Gl 


\EXERC\CAP3\JAVA\EX18.java e NEXERCICAP3iJAVANEX18.class 


ELJ Cada degrau de uma escada tem X de altura. Faça um programa que receba essa altura e a altura que 
o usuário deseja alcançar subindo a escada, calcule e mostre quantos degraus ele deverá subir para 
atingir seu objetivo, sem se preocupar com a altura do usuário. Todas as medidas fornecidas devem 
estar em metros. 


Altura que o 


usuário deseja 4-— 
alcançar 


—— Altura do degrau 


(AILTGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE a degrau, a usuario, qtd degraus NUMÉRICO 
LEIA a degrau 
LEIA a usuario 
gqtd degraus + a usuario / a degrau 
ESCREVA qtd degraus 
FIM ALGORITMO. 
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PASCAL [Sono 
c 


\EXERC\CAP3\PASCAL\EX19.PAS e \EXERC\CAP3\PASCAL\EX19.EXE 


eylen Ra SoLução: 


GM 
\EXERC\CAP3\C++\EX19.CPP e \EXERC\CAP3\C++\EX19.EXE 


RANA SOLUÇÃO: 
EEE 


\EXERC\CAP3\JAVA\EX19.java e VEXERCICAP3AJAVANEX19.class 


EIA Faça um programa que receba a medida do ângulo (em graus) formado por uma escada apoiada no 
chão e encostada na parede e a altura da parede onde está a ponta da escada. Calcule e mostre a me- 
dida dessa escada. 


Observação: as funções trigonométricas implementadas nas linguagens de programação trabalham 
com medidas de ângulos em radianos. 


escada 
parede 
a 
chão 
(ALLISIOJRN ITIMO) Sorução: 
ALGORITMO 

DECLARE ang, alt, escada, radiano NUMÉRICO 
LEIA ang 
LEIA alt 


radiano + ang * 3.14 / 180 
escada < alt / seno(radiano) 
ESCREVA escada 

FIM ALGORITMO. 


PASCAL SoLUÇÃO: 
CHER 


VEXERCACAP3NPASCALVEX20.PAS e VEXERCICAP3NPASCALNEX20.EXE 


C/C++ [SURTO 
CER 


\EXERC\CAP3\C++\EX20.CPP e \EXERC\CAP3\C++\EX20.EXE 


RNA SoLução: 


\EXERC\CAP3\JAVA\EX20.java e VEXERCICAP3AJAVANEX20.class 


PIE Uma pessoa deseja pregar um quadro em uma parede. Faça um programa para calcular e mostrar a 
que distância a escada deve estar da parede. A pessoa deve fornecer o tamanho da escada e a altura em 
que deseja pregar o quadro. 


Lembre-se de que o tamanho da escada deve ser maior que a altura que se deseja alcançar. 
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Medida da escada 


X — Altura em que deseja pregar o quadro 


Y — Distância em que deverá ficar a escada 
a 


Distância que a escada está da parede Z = Tamanho da escada 


(ALLISIOJELITIMO) Solução: 


ALGORITMO 
DECLARE X, Y, Z NUMÉRICO 
LEIA Z 
LEIA X 
vez x 
Y = 4Y 
ESCREVA Y 

FIM ALGORITMO. 


PINN SOLUÇÃO: 
GEE 
VEXERCACAP3NPASCALVEX21.PAS e VEXERCACAP3NPASCALNEX21.EXE 
eyler Ra Sotução: 
e i) 
\EXERC\CAP3\C++\EX21.CPP e \EXERC\CAP3\C++\EX21.EXE 


BAIA SoLução: 
GRE 
\EXERC\CAP3\JAVA\EX21.java e VEXERCICAP3AJAVANEX21.class 


EYA Sabe-se que o quilowatt de energia custa um quinto do salário mínimo. Faça um programa que rece- 
ba o valor do salário mínimo e a quantidade de quilowatts consumida por uma residência. Calcule e 
mostre: 

a) o valor de cada quilowatt; 
b) o valor a ser pago por essa residência; 
c) o valor a ser pago com desconto de 15%. 


(ALLISIOJEL TIM) Solução: 


ALGORITMO 
DECLARE vlr sal, qgtd kw, vlr kw, vlr reais, desc, vlr desc NUMÉRICO 
LEIA vlr sal 
LEIA qtd kw 
vlr kw + vlr sal / 5 
vlr reais — vlr kw * qtd kw 
desc + vlr reais * 15 / 100 
vlr desc <— vlr reais — desc 
ESCREVA vlr kw 
ESCREVA vlr reais 
ESCREVA vlr desc 


FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
SEER 
VEXERCACAP3NPASCALVEX22.PAS e \EXERC\CAP3\PASCAL\EX22. EXE 
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C/c++ ENIO 
GER 


\EXERC\CAP3\C++\EX22.CPP e \EXERC\CAP3\C++\EX22.EXE 


RB WIA UA SoLução: 
[= 


\EXERC\CAP3\JAVA\EX22.java e VEXERCICAP3AJAVANEX22.class 


FEJ Faça um programa que receba um número real, encontre e mostre: 
a) a parte inteira desse número; 
b) a parte fracionária desse número; 
c) o arredondamento desse número. 


(ALLISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE num, i, f, a NUMÉRICO 
LEIA num 
i — parte inteira de num 
aR = A — dl 
a + arredonda (num) 
ESCREVA i 
ESCREVA f 
ESCREVA a 
FIM ALGORITMO. 


2J Ne10 NA SOLUÇÃO (ARREDONDANDO O NÚMERO COMO NA MATEMÁTICA): 


\ EXERC \CAP3\PASCAL\EX23.PAS e NEXERCACAP3NPASCALNEX23.EXE 


[ePAeR T 12 soLução (ARREDONDANDO O NÚMERO PARA CIMA): 
m] \EXERC\CAP3 \C++\EX23_A.CPP e \EXERC\CAP3\C++\EX23_A. EXE 


22 SOLUÇÃO (ARREDONDANDO O NÚMERO PARA BAIXO): 


\EXERC\CAP3\C++\EX23_B.CPP e \EXERC\CAP3\C++\EX23_B.EXE 


a Ñ 1 . 
JAVA 12 soLução (ARREDONDANDO O NÚMERO PARA CIMA): 


(7 | NEXERCACAP3NJAVANEX23 A.java e VEXERCICAP3NJAVAVEX23 A.class 


22 SOLUÇÃO (ARREDONDANDO O NÚMERO PARA BAIXO): 


NEXERCACAP3NJAVANEX23 B.java e NEXERCICAP3NJAVANEX23 B.class 


PLA Faça um programa que receba uma hora formada por hora e minutos (um número real), calcule e 
mostre a hora digitada apenas em minutos. Lembre-se de que: 


para quatro e meia, deve-se digitar 4.30; 
os minutos vão de 0 a 59. 


ALIRIM) Solução: 


ALGORITMO 
DECLARE hora, h, m, conversao NUMÉRICO 
LEIA hora 
h <— pegar a parte inteira da variável hora 
m< hora h 


conversao + (h * 60) + (m * 100) 
ESCREVA conversao 
FIM ALGORITMO. 


50 | Fundamentos da programação de computadores 


PASCAL, SoLUÇÃO: 
GER 
VEXERCACAP3NPASCALVEX24.PAS e VEXERCACAP3NPASCALNEX24.EXE 


C/C++ Sorução: 
[= 


\EXERC\CAP3\C++\EX24.CPP e NEXERCÂCAP3AC++NEX24 .EXE 


BAIANO SOLUÇÃO: 
EE 


\EXERC\CAP3\JAVA\EX24.java e NEXERCICAP3AJAVANEX24.class 


FER Faça um programa que receba o custo de um espetáculo teatral e o preço do convite desse espetáculo. 
Esse programa deverá calcular e mostrar a quantidade de convites que devem ser vendidos para que, 
pelo menos, o custo do espetáculo seja alcançado. 


(AILTGJOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE custo, convite, qtd NUMÉRICO 
LEIA custo 
LEIA convite 
qtd + custo / convite 
ESCREVA qtd 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
S 
\ EXERC \CAP3\PASCAL\EX25.PAS e \EXERC\CAP3\PASCAL\EX25. EXE 


C/C++ EO 
EE 
\EXERC\CAP3\C++\EX25.CPP e NEXERCACAP3AC++NEX25. EXE 


JAVA A SoLuçÃo: 
ES) 
\EXERC\CAP3\JAVA\EX25.java e NEXERCICAP3NJAVANEX25.class 


EXERCÍCIOS PROPOSTOS 


BEER Faça um programa que receba dois números, calcule e mostre a subtração do primeiro número pelo 
segundo. 


IFA Faça um programa que receba três números, calcule e mostre a multiplicação desses números. 
IEA Faça um programa que receba dois números, calcule e mostre a divisão do primeiro número pelo 


segundo. Sabe-se que o segundo número não pode ser zero, portanto, não é necessário se preocupar 
com validações. 


EA Faça um programa que receba duas notas, calcule e mostre a média ponderada dessas notas, consi- 
derando peso 2 para a primeira e peso 3 para a segunda. 

BEAR Faça um programa que receba o preço de um produto, calcule e mostre o novo preço, sabendo-se 
que este sofreu um desconto de 10%. 


EA Um funcionário recebe um salário fixo mais 4% de comissão sobre as vendas. Faça um programa 
que receba o salário fixo do funcionário e o valor de suas vendas, calcule e mostre a comissão e seu 
salário final. 

IEA Faça um programa que receba o peso de uma pessoa, calcule e mostre: 

a) o novo peso, se a pessoa engordar 15% sobre o peso digitado; 


b) o novo peso, se a pessoa emagrecer 20% sobre o peso digitado. 
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REA Faça um programa que receba o peso de uma pessoa em quilos, calcule e mostre esse peso em gramas. 
REA Faça um programa que calcule e mostre a área de um trapézio. 

Sabe-se que: A = ((base maior + base menor) * altura)/2 
EXMA Faça um programa que calcule e mostre a área de um quadrado. Sabe-se que: A = lado * lado. 


EEB Faça um programa que calcule e mostre a área de um losango. Sabe-se que: A = (diagonal maior * dia- 
gonal menor)/2. 


EFA Faça um programa que receba o valor do salário mínimo e o valor do salário de um funcionário, calcule 
e mostre a quantidade de salários mínimos que esse funcionário ganha. 


EEA Faça um programa que calcule e mostre a tabuada de um número digitado pelo usuário. 


Exemplo: 

Digite um número: 5 

Sx0=0 SxS5S=25 
5x1=5 5 x6=30 
5x2=10 5x7=35 
5x3=15 EE 

—> x = 

RE 5 x 10 = 50 


ELA Faça um programa que receba o ano de nascimento de uma pessoa e o ano atual, calcule e mostre: 
a) a idade dessa pessoa em anos; 
b) 
c) a idade dessa pessoa em dias; 
) 


d 


HA João recebeu seu salário e precisa pagar duas contas atrasadas. Em razão do atraso, ele deverá pagar 
multa de 2% sobre cada conta. Faça um programa que calcule e mostre quanto restará do salário de 
João. 


a idade dessa pessoa em meses; 


a idade dessa pessoa em semanas. 


HA Faça um programa que receba o valor dos catetos de um triângulo, calcule e mostre o valor da hipo- 
tenusa. 

EFA Faça um programa que receba o raio, calcule e mostre: 
a) o comprimento de uma esfera; sabe-se que C = 2 * m R; 
b) a área de uma esfera; sabe-se que A = q R?; 


c) o volume de uma esfera; sabe-se que V = % * m R3. 


EEJ Faça um programa que receba uma temperatura em Celsius, calcule e mostre essa temperatura em 
Fahrenheit. Sabe-se que F = 180*(C + 32)/100. 


ELJ Sabe-se que, para iluminar de maneira correta os cômodos de uma casa, para cada mí, deve-se usar 18 W 
de potência. Faça um programa que receba as duas dimensões de um cômodo (em metros), calcule e mostre 
a sua área (em m?) e a potência de iluminação que deverá ser utilizada. 

EIH Faça um programa que receba a medida do ângulo formado por uma escada apoiada no chão e a dis- 


tância em que a escada está da parede, calcule e mostre a medida da escada para que se possa alcançar 
sua ponta. 


Medida da escada 


Distância que a escada está da parede 


PIE Faça um programa que receba o número de horas trabalhadas, o valor do salário mínimo e o número 
de horas extras trabalhadas, calcule e mostre o salário a receber, de acordo com as regras a seguir: 
a) a hora trabalhada vale 1/8 do salário mínimo; 


b) a hora extra vale 1/4 do salário mínimo; 
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c) o salário bruto equivale ao número de horas trabalhadas multiplicado pelo valor da hora trabalhada; 

d) a quantia a receber pelas horas extras equivale ao número de horas extras trabalhadas multiplicado pelo valor 
da hora extra; 

e) o salário a receber equivale ao salário bruto mais a quantia a receber pelas horas extras. 

EFA Faça um programa que receba o número de lados de um polígono convexo, calcule e mostre o número 
de diagonais desse polígono. Sabe-se que ND = N * (N — 3)/2, em que N é o número de lados do 
polígono. 

PER Faça um programa que receba a medida de dois ângulos de um triângulo, calcule e mostre a medida do 
terceiro ângulo. Sabe-se que a soma dos ângulos de um triângulo é 180 graus. 

ELZA Faça um programa que receba a quantidade de dinheiro em reais que uma pessoa que vai viajar possui. Ela 
vai passar por vários países e precisa converter seu dinheiro em dólares, marco alemão e libra esterlina. Sabe- 
-se que a cotação do dólar é de R$ 1,80; do marco alemão, de R$ 2,00; e da libra esterlina, de R$ 3,57. O 
programa deve fazer as conversões e mostrá-las. 

FER Faça um programa que receba uma hora (uma variável para hora e outra para minutos), calcule e 
mostre: 

a) a hora digitada convertida em minutos; 
b) o total dos minutos, ou seja, os minutos digitados mais a conversão anterior; 
c) o total dos minutos convertidos em segundos. 


CAPÍTULO 


Estrutura 


condicional 


4.1 Estrutura condicional em algoritmos 


À estrutura condicional em algoritmos pode ser simples ou composta. 


41.1 Estrutura condicional simples 


SE condição 
ENTÃO comando 


O comando só será executado se a condição for verdadeira. Uma condição é uma comparação que 
possui dois valores possíveis: verdadeiro ou falso. 


SE condição 

ENTÃO INÍCIO 
comandol 
comando? 
comando3 
FIM 


Os comandos 1, 2 e 3 só serão executados se a condição for verdadeira. As palavras INÍCIO e FIM 
serão necessárias apenas quando dois ou mais comandos forem executados. 


41.2 Estrutura condicional composta 


SE condição 
ENTÃO comandol 
SENÃO comando? 


Se a condição for verdadeira, será executado o comando1; caso contrário, será executado o comando2. 


SE condição 

ENTÃO INÍCIO 
comandol 
comando? 
FIM 


SENÃO INÍCIO 
comando3 
comando4 
FIM 
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Se a condição for verdadeira, o comandol € O comando2 serão executados; caso contrário, o comando3 
e o comando4 serão executados. 


4.2 Estrutura condicional em PASCAL 


A seguir, serão apresentadas três estruturas condicionais em PASCAL (simples, composta e case) e os 
operadores lógicos. 


4.21 Estrutura condicional simples 


IF condição 
THEN comando; 


O comando só será executado se a condição for verdadeira. Uma condição é uma comparação que 
possui dois valores possíveis: verdadeiro ou falso. 


IF condição 

THEN BEGIN 
comandol ; 
comando? ; 
comando3; 
END; 


Os comandos 1, 2 e 3 só serão executados se a condição for verdadeira. 


4.2.2 Estrutura condicional composta 


IF condição 
THEN comandol 
ELSE comando? ; 


Se a condição for verdadeira, será executado o comando1; caso contrário, será executado o comando2. 


IF condição 

THEN BEGIN 
comandol ; 
comando? ; 
END 

ELSE BEGIN 
comando3; 
comando4 ; 
END; 


Se a condição for verdadeira, o comandol € o comando? serão executados; se for falsa, o comando3 e o 
comando4 serão executados. 


QOQ Observação 


Antes do comando ELSE não existe ponto e vírgula. 


4.2.3 Estrutura case 


Em alguns programas, existem situações mutuamente exclusivas, isto é, se uma situação for executada, 
as demais não serão. Quando este for o caso, um comando seletivo será o mais indicado, e esse comando, 
em PASCAL, tem a seguinte sintaxe: 
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CASE seletor OF 
lista de alvosl: comandol; 
lista de alvos2: comando2; 
alvo3: comando3; 
alvo4: BEGIN 
comando4 ; 
comandos ; 
END; 
END; 


Se o seletor atingir a lista de alvosl, O comando1 será executado; se atingir a lista de alvos2, 
O comando? será executado; se atingir o alvo3, o comando3 será executado; e, se atingir o alvo4, então, o 
comando4 e O comando5 serão executados. Se nenhum alvo for atingido, nada será executado. 


CASE seletor OF 
lista de alvosl: BEGIN 
comandol ; 
comando? ; 
END; 
lista de alvos2: comando3; 
ELSE comando4 ; 
END; 


Na estrutura CASE acima, se nenhum alvo for atingido os comandos da estrutura ELSE serão executados. 


Exemplo: 


program teste; 

uses crt; 

var i: integer; 

begin 

clrscr; 

writeln('Digite um número”'); 

readln (i); 

case i of 
1: writeln('Número 1'); 
2,5,6:writeln('Número 2 ou número 5 ou número 6'); 
7..10:writeln('Número entre 7 e 10'); 
else writeln('outro número”); 

end; 

readln; 

end. 


À restrição da estrutura case é que o seletor só pode ser uma variável do tipo char, integer ou boolean. 


4.2.4 Operadores lógicos 


Os principais operadores lógicos são: AND, OR e NOT, que significam e, ou, não e são usados para con- 
junção, disjunção e negação, respectivamente. 


TABELA E TABELA OU TABELA NÃO 
VeV=V VouV=V Não V = F 
VeF=F VouF=YV Não F=V 
FeV=F FouV=V 


FeFf=F FouF=F 
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GO Observações 


Na linguagem PASCAL, quando existe mais de uma condição, elas devem estar entre parênteses. 


Exemplos: 
IFx=3 
THEN WRITELN('Número igual a 3'); 
No exemplo, existe apenas uma condição, logo, os parênteses são opcionais. 
IF (X > 5) AND (X < 10) 
THEN WRITELN('Número entre 5 e 10'); 
No exemplo anterior, existe mais de uma condição, logo, os parênteses são obrigatórios, ou seja, 
cada condição deve estar entre parênteses. 


IF ((X = 5) AND (Y = 2)) OR (Y = 3) 


THEN WRITELN('X é igual a 5 e Y é igual a 2, ou Y é igual a 3'); 

No exemplo anterior, existe mais de uma condição e mais de um tipo de operador lógico, logo, 
além dos parênteses de cada condição, devem existir ainda parênteses que indiquem a prioridade de 
execução das condições. Nesse exemplo, as condições com o operador AND, ou seja, ((X = 5) AND (Y 
=2)), serão testadas e seu resultado será testado com a condição OR (Y = 3). 


IF (X= 5) AND ((Y = 2) OR (Y = 3)) 


THEN WRITELN('X é igual a 5, e Y é igual a 2 ou Y é igual a 3'); 


Neste exemplo, existe mais de uma condição e mais de um tipo de operador lógico, logo, além dos 
parênteses de cada condição, devem existir ainda parênteses que indiquem a prioridade de execução das 
condições. Aqui, as condições com o operador OR, ou seja, ((Y = 2) OR (Y = 3)), serão testadas, e seu 
resultado será testado com a condição AND (X = 5). 


4.3 Estrutura condicional em C/C++ 


A seguir, serão apresentadas três estruturas condicionais em C/C++ (simples, composta e case) e os 
operadores lógicos. 


4.3.1 Estrutura condicional simples 


if (condição) 
comando ; 


O comando só será executado se a condição for verdadeira. Uma condição é uma comparação que 
possui dois valores possíveis: verdadeiro ou falso. 


if (condição) 


{ 
comandol; 
comando2; 
comando3; 
} 


Em C/C++, torna-se obrigatória a utilização de chaves quando existe mais de um comando a executar. 
Os comandos entre chaves { | só serão executados se a condição for verdadeira. 
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4.3.2 Estrutura condicional composta 


if (condição) 
comandol ; 

else 
comando? ; 


Se a condição for verdadeira, será executado o comando1; se for falsa, será executado o comando2. 


if (condição) 


{ 
comandol ; 
comando? ; 
} 
else 
{ 
comando3; 
comando4 ; 
} 


Se a condição for verdadeira, o comando1 € o comando2 serão executados; caso contrário, o comando3 
e o comandos serão executados. 


4.3.3 Estrutura case 


Em alguns programas, existem situações mutuamente exclusivas, isto é, se uma situação for executada, 
as demais não serão. Quando este for o caso, um comando seletivo é o mais indicado. Esse comando em C/ 
C++ tem a seguinte sintaxe: 


switch (variável) 


{ 

case valorl: lista de comandos; 
break; 

case valor2: lista de comandos; 
break; 


default: lista de comandos; 


} 


O comando switch(variável) avalia o valor de uma variável para decidir qual case será executado. 
Cada case está associado a UM possível valor da variável, que deve ser, obrigatoriamente, do tipo char, 
unsigned char, int, unsigned int, short int, long Ou unsigned long. 

O comando break deve ser utilizado para impedir a execução dos comandos definidos nos cases sub- 


sequentes. Quando o valor da variável não coincidir com aqueles especificados nos cases, será executado 
então o default. 


Exemplo: 


include <stdio.h> 
int main() 
{ 
int i; 
printf(“Digite um número "); 
scanf(“Sd%*c”,&i); 
switch (i) 
{ 
case 1: 
printf(“Número 1”); 
break; 
case 2: 
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printf(“Número 2"); 
break; 
default: 
printf(“Número diferente de 1 e de 2"); 
} 
getchar(); 
return 0; 


4.3.4 Operadores lógicos 
Os principais operadores lógicos são: &&, | | e !, que significam e, ou, não e são usados para conjunção, 
disjunção e negação, respectivamente. 


TABELA E TABELA OU TABELA NÃO 
VeV=V VouV=V Não V = F 
VeF=F VouF=V Não F=V 
FeV=F FouV=V 

FeF=F FouF=F 


siere Observações 


Na linguagem C/C++, todas as condições devem estar entre parênteses. 


Exemplos: 


if (x == 3) 
printf(“Número igual a 3"); 


No exemplo anterior, existe apenas uma condição que, obrigatoriamente, deve estar entre parênteses. 


if (X> 5 ea X< 10) 
printf(“Número entre 5 e 10"); 


No exemplo anterior, existe mais de uma condição, as quais, obrigatoriamente, devem estar entre 
parênteses. 


if ((X == 5 && Y == 2) || Y == 3) 
printf(“X é igual a 5 e Y é igual a 2, ou Y é igual a 3”); 


No exemplo anterior, existe mais de uma condição e mais de um tipo de operador lógico, logo, além 
dos parênteses que envolvem todas as condições, devem existir ainda parênteses que indiquem a priori- 


dade de execução das condições. Aqui, as condições com o operador &&, ou seja, (X == 5 && Y == 2), 
serão testadas. Seu resultado será testado com a condição | | == 3. 
if (X == 5 && (Y == || ¥ == 3)) 


printf(“X é igual a 5, e Y é igual a 2 ou Y é igual a 3”); 


No exemplo anterior, existe mais de uma condição e mais de um tipo de operador lógico, portanto, 
além dos parênteses que envolvem todas as condições, devem existir ainda parênteses que indiquem a 
prioridade de execução das condições. Nesse exemplo, as condições com o operador ||, ou seja, (Y == 
2 || Y == 3), serão testadas. Seu resultado será testado com a condição && x == 


4.4 Estrutura condicional em JAVA 


À seguir, serão apresentadas três estruturas condicionais em JAVA (simples, composta e case) e os ope- 
radores lógicos. 
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4.4.1 Estrutura condicional simples 


if (condição) 
comando ; 


O comando só será executado se a condição for verdadeira. Uma condição é uma comparação que 
possui dois valores possíveis: verdadeiro ou falso. 


if (condição) 


{ 
comandol ; 
comando? ; 
comando3; 
} 


Em JAVA, torna-se obrigatória a utilização de chaves quando existe mais de um comando a executar. 
Os comandos entre chaves { | só serão executados se a condição for verdadeira. 


4.4.2. Estrutura condicional composta 


if (condição) 
comandol ; 
else 
comando? ; 


Se a condição for verdadeira, será executado o comandol; caso contrário, será executado o comando2. 


if (condição) 


{ 
comandol ; 
comando? ; 
} 
else 
{ 
comando3; 
comando4 ; 
} 


Se a condição for verdadeira, o comando1 e o comando2 serão executados; se for falsa, o comando3 
e o comando4 serão executados. 


4.4.3 Estrutura case 


Em alguns programas, existem situações mutuamente exclusivas, isto é, se uma situação for executada, 


as demais não serão. Quando este for o caso, um comando seletivo é o mais indicado, e esse comando, em 
JAVA, tem a seguinte sintaxe: 


switch (variável) 


{ 

case valorl: lista de comandos; 
break; 

case valor2: lista de comandos; 
break; 


default: lista de comandos; 


} 


O comando switch (variável) analisa o valor de uma variável para decidir qual case será executa- 


do. Cada case está associado a UM possível valor da variável, que deve ser obrigatoriamente do tipo int, 
short, byte ou char. 
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O comando break deve ser utilizado para impedir a execução dos comandos definidos nos cases sub- 


sequentes. 
Quando o valor da variável não coincidir com aqueles especificados nos cases, será executado, então, 


o default. 
Exemplo: 


import java.io.*; 
import java.util.*; 
class teste 


{ 
public static void main(String args[]) 
{ 
int x; 
Scanner dado; 
System.out.println(“Digite um número “); 
dado = new Scanner (System. in); 
x = dado.nextInt(); 
switch (x) 
{ 
case 1: System.out.println(“Número 1”); 
break; 
case 2: System.out.println(“Número 2"); 
break; 
default: System.out.println(“Outro número”); 
} 
} 
} 


4.4.4 Operadores lógicos 
Os principais operadores lógicos são: &&, | | e !, que significam e, ou, não e são usados para conjunção, 
disjunção e negação, respectivamente. 


TABELA E TABELA OU TABELA NÃO 
VeV=V VouV=V Não V=F 
VeF=F VouF=V Não F=V 
FeV=F FouV=V 

FeF=F Fou F=F 


siere Observações 


Na linguagem JAVA, todas as condições devem estar entre parênteses. 


Exemplos: 
if (x == 3) 
System.out.println(“Número igual a 3"); 
No exemplo anterior, existe apenas uma condição que, obrigatoriamente, deve estar entre parênteses. 


if (X> 5 && X< 10) 
System.out.println(“Número entre 5 e 10"); 
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No exemplo anterior, existe mais de uma condição, as quais, obrigatoriamente, devem estar 
entre parênteses. 
if ((X == 5 && Y == 2) || Y == 3) 


System.out.println(“X é igual a 5 e Y é igual a 2, ou Y é igual a 3"); 


No exemplo anterior, existe mais de uma condição e mais de um tipo de operador lógico, por- 
tanto, além dos parênteses que envolvem todas as condições, devem existir ainda parênteses que 
indiquem a prioridade de execução das condições. Nesse exemplo, as condições com o operador &&, 
ou seja, (X == 5 && Y == 2), serão testadas, e seu resultado será testado com a condição || Y == 


if (X == 5 && (Y == [| Y == 3)) 
System.out.println(“X é igual a 5, e Y é igual a 2 ou Y é igual a 3"); 


No exemplo anterior, existe mais de uma condição e mais de um tipo de operador lógico, por- 
tanto, além dos parênteses que envolvem todas as condições, devem existir ainda parênteses que 
indiquem a prioridade de execução das condições. Nesse exemplo, as condições com o operador | |, 
ou seja, (Y == 2 || Y == 3), serão testadas, e seu resultado será testado com a condição && X == 


EXERCÍCIOS RESOLVIDOS 


EEB A nota final de um estudante é calculada a partir de três notas atribuídas, respectivamente, a um traba- 
lho de laboratório, a uma avaliação semestral e a um exame final. A média das três notas mencionadas 
obedece aos pesos a seguir: 


NOTA PESO 
Trabalho de laboratório 2 
Avaliação semestral 3 
Exame final 5 


Faça um programa que receba as três notas, calcule e mostre a média ponderada e o conceito que segue 
a tabela: 


MÉDIA PONDERADA CONCEITO 
8,0 eso 10,0 A 
7,0 e—o 8,0 
6,0 e—o 7,0 
5,0 e——o 6,0 
0,0 e—o 5,0 


mona» 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE nota trab, aval sem, exame, media NUMÉRICO 
ESCREVA “Digite a nota do trabalho de laboratório: ” 
LEIA nota trab 

ESCREVA “Digite a nota da avaliação semestral: “” 
LEIA aval sem 

ESCREVA “Digite a nota do exame final: ” 

LEIA exame 

media +— (nota trab * 2 + aval sem * 3 + exame * 5) / 10 
ESCREVA “Média ponderada: ” , media 

SE media >= 8 E media <= 10 
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ENTÃO ESCREVA “Obteve conceito A” 
SE media >= 7 E media < 8 

ENTÃO ESCREVA “Obteve conceito B” 
SE media >= 6 E media < 7 

ENTÃO ESCREVA “Obteve conceito C” 
SE media >= 5 E media < 6 

ENTÃO ESCREVA “Obteve conceito D” 
SE media >= 0 E media < 5 

ENTÃO ESCREVA “Obteve conceito E” 
FIM ALGORITMO. 


INSANA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
ed) NEXERCNCAP4 YPASCALNEX1 A.PAS e EXERCICAP4NPASCALNEX1 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NPASCALNEX1 B.PAS e \EXERC\CAP4\PASCAL\EX1_B.EXE 
VLt HUM 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
VEXERCACAP4NC++NEX1 A.CPP e \EXERC\CAP4\C++\EX1_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NC++NEX1 B.CPP e \EXERC\CAP4\C++\EX1_B.EXE 


JAVA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) VEXERCNCAP4NJAVANEXI A. java e NEXERCICAP4NJAVANEX1 A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NJAVANEXI B.java e \EXERC\CAP4\JAVA\EX1_B.class 


IFA Faça um programa que receba três notas de um aluno, calcule e mostre a média aritmética e a mensagem 
constante na tabela a seguir. Aos alunos que ficaram para exame, calcule e mostre a nota que deverão 
tirar para serem aprovados, considerando que a média exigida é 6,0. 


MÉDIA ARITMÉTICA MENSAGEM 
0,0 e—o 30 Reprovado 
3,0 eo 7,0 Exame 
7,0 e. 100 Aprovado 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE notal, nota2, nota3, media, nota exame NUMÉRICO 
ESCREVA “Digite a primeira nota: “ 
LEIA notal 
ESCREVA “Digite a segunda nota: “ 
LEIA nota2 
ESCREVA “Digite a terceira nota: “ 
LEIA nota3 
media <— (notal + nota2 + nota3) / 3 
ESCREVA “Média aritmética: “,media 
SE media >= 0 E media < 3 
ENTÃO ESCREVA “Reprovado” 
SE media >= 3 E media < 7 
ENTÃO INÍCIO 
ESCREVA “Exame” 
nota exame <— 12 - media 
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ESCREVA “Deve tirar nota”, nota exame, “para ser aprovado” 
FIM 
SE media >= 7 E media <= 10 
ENTÃO ESCREVA “Aprovado” 
FIM ALGORITMO. 


INSA 13 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) VEXERC NCAP4NPASCALVEX2 A.PAS e VEXERCICAP4NPASCALNEX2 A.EXE 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


NEXERCICAP4NPASCALNEX2 B.PAS e NEXERCICAP4PASCALNEX2 B.EXE 
C/C++ 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
\EXERC\CAP4\C++\EX2_A.CPP e \EXERC\CAP4\C++\EX2_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NC++NEX2 B.CPP e \EXERC\CAP4\C++\EX2_B.EXE 


JAVA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) NEXERCNCAP4NJAVANEX2 A. java e NEXERCICAP4NJAVANEX2 A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NJAVANEX2 B.java e VEXERCACAP4JAVANEX2 B.class 


IEA Faça um programa que receba dois números e mostre o maior. 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE numl, num2 NUMÉRICO 
ESCREVA “Digite o primeiro número: “ 
LEIA numl 
ESCREVA “Digite o segundo número: ” 
LEIA num2 
SE numl > num2 
ENTÃO ESCREVA “O maior número é: “, numl 
SE num2 > numl 
ENTÃO ESCREVA “O maior número é: “, num2 
SE numl = num2 
ENTÃO ESCREVA “Os números são iguais “ 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
VEXERCACAP4NPASCALVEX3 A.PAS e NEXERCICAP4NPASCALNEX3 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
NEXERCICAP4NPASCALNEX3 B.PAS e NEXERCACAP4NPASCALNEX3 B.EXE 


C/C++ 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
VEXERCACAP4NC++NEX3 A.CPP e NEXERCICAP4CHEX3 A. EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
VEXERCACAP4NC++NEX3 B.CPP e \EXERC\CAP4\C++\EX3_B.EXE 
JAVA 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
\EXERC\CAP4\JAVA\EX3_A. java e VEXERCICAP4AJAVANEX3 A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
VEXERCACAP4NJAVANEX3 B.java e \EXERC\CAP4\JAVA\EX3_B.class 


64 | Fundamentos da programação de computadores 


EA Faça um programa que receba três números e mostre-os em ordem crescente 


digitará três números diferentes. 
(AILIGIOJRIN' ITIMO) SoLução: 


ALGORITMO 
DECLARE numl, num2, num3 NUMÉRICO 
ESCREVA “Digite o primeiro número: “” 


LEIA numl 
ESCREVA “Digite o segundo número: ” 
LEIA num2 
ESCREVA “Digite o terceiro número: “ 
LEIA num3 


SE numi < num2 E numl < num3 
ENTÃO SE num2 < num3 


. Suponha que o usuário 


ENTÃO ESCREVA “A ordem crescente é: “,numl,“-”,num2,“-",num3 
SENÃO ESCREVA “A ordem crescente é: “,numl,”-"”,num3,”-"”,num2 


SE num2 < numl E num2 < num3 
ENTÃO SE numl < num3 


ENTÃO ESCREVA “A ordem crescente é: “,num2,“-”,numl,“-",num3 
SENÃO ESCREVA “A ordem crescente é: “,num2,”-”,num3,”-”,numl 


SE num3 < numl E num3 < num2 
ENTÃO SE numl < num2 


ENTÃO ESCREVA “A ordem crescente é: “,num3,”-”,numl,”-”,num2 
SENÃO ESCREVA “A ordem crescente é: “,num3,”“-”,num2,”“-",numl 


FIM ALGORITMO. 


INSANA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) NEXERCNCAP4 VPASCALVEX4 A.PAS e VEXERCÍCAP4NPASCALNEX4 A. EXE 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NPASCALNEX4 B.PAS e NEXERCICAP4PASCALNEX4 B.EXE 


C/C++ 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
\EXERC\CAP4\C++\EX4_A.CPP e \EXERC\CAP4\C++\EX4_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
\EXERC\CAP4\C++\EX4_B.CPP e \EXERC\CAP4\C++\EX4_B.EXE 
1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) VEXERCNCAP4NJAVANEXA A. java e NEXERCICAP4NJAVANEX4 A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NJAVANEX4 B.java e NEXERCICAP4JAVANEX4 B.class 


REA Faça um programa que receba três números obrigatoriamente em ordem crescente e um quarto núme- 
ro que não siga essa regra. Mostre, em seguida, os quatro números em ordem decrescente. Suponha 


que o usuário digitará quatro números diferentes. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE numl, num2, num3, num4 NUMÉRICO 

ESCREVA “Digite três números em ordem crescente: “ 
LEIA numl 

LEIA num? 

LEIA num3 

ESCREVA “Digite um número (fora de ordem): “ 

LEIA num4 

SE num4 > num3 
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ENTÃO ESCREVA “A ordem decrescente é: 

SE num4 > num2 E num4 < num3 

ENTÃO ESCREVA “A ordem decrescente é: 
SE num4 > numl E num4 < num2 

ENTÃO ESCREVA “A ordem decrescente é: 
SE num4 < numl 

ENTÃO ESCREVA “A ordem decrescente é: 
FIM ALGORITMO. 


“, num4,“-", num3,”-"”,num2,”-"”,numl 
“,num3,º-” ,num4,“-”, num2,“º-”,numl 
“,num3,º-" ,num2,“º-”, numg, 


“r” ,numl 


“ num3,“º-",num2,º-”,numl,”-", numá 


Nee 13 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 

D \EXERC\CAP4\PASCAL\EX5_A.PAS e \EXERC\CAP4\PASCAL\EX5_A. EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
\EXERC\CAP4\PASCAL\EX5_B.PAS e \EXERC\CAP4\PASCAL\EX5_B.EXE 

C/C++ 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
\EXERC\CAP4\C++\EX5_A.CPP e \EXERC\CAP4\C++\EX5_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
\EXERC\CAP4\C++\EX5_B.CPP e \EXERC\CAP4\C++\EX5_B.EXE 
AGIA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
VEXERCACAP4JAVANEX5 A.java e \EXERC\CAP4\JAVA\EX5_A.class 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


\EXERC\CAP4\JAVA\EX5_B.java e \EXERC\CAP4\JAVA\EX5_B.class 


WA Faça um programa que rec 
(AILIGIOJRILITIMIO) SoLução: 


eba um número inteiro e verifique se é par ou ímpar. 


ALGORITMO 
DECLARE num, r NUMÉRICO 
ESCREVA “Digite um número: “” 
LEIA num 
ER num 
RESTO ( /2) 
SE r = 0 
ENTÃO ESCREVA “O número é par” 
SENÃO ESCREVA “O número é ímpar” 
FIM ALGORITMO. 
I Ne{6 N 1º SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
ed) NEXERCNCAP4 VPASCALVEX6 A.PAS e VEXERCÍCAP4NPASCALNEX6 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
NEXERCICAP4NPASCALNEX6 B.PAS e \EXERC\CAP4\PASCAL\EX6_B. EXE 
C/C++ 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
a) VEXERC \CAP4\C++\EX6_A.CPP e \EXERC\CAP4\C++\EX6_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
\EXERC\CAP4\C++\EX6_B.CPP e \EXERC\CAP4\C++\EX6_B.EXE 
JAVA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
(C) \EXERC\CAP4 \JAVA\EX6_A.java e \EXERC\CAP4\JAVA\EX6_A.class 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NJAVANEX6 B.java e NEXERCICAP4NJAVANEX6 B.class 
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IEA Faça um programa que receba quatro valores: I, A, Be C. Desses valores, I é inteiro e positivo, A, B e 
C são reais. Escreva os números A, B e C obedecendo à tabela a seguir. 
Suponha que o valor digitado para I seja sempre um valor válido, ou seja, 1,2 ou 3, e que os números 
digitados sejam diferentes um do outro. 


VALOR DE | FORMA A ESCREVER 
1 A, Be C em ordem crescente. 
2 A, Be C em ordem decrescente. 
3 O maior fica entre os outros dois números. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE A, B, C, 1 NUMÉRICO 
ESCREVA “Digite um valor para A:” 
LEIA A 
ESCREVA “Digite um valor para B:” 
LEIA B 
ESCREVA “Digite um valor para C:” 
LEIA C 
ESCREVA “Digite um valor para I (1, 2 ou 3):” 
LEIA I 
SE I=1 
ENTÃO INÍCIO 
SE A<B E A<C 
ENTÃO SE B<C 
ENTÃO ESCREVA “A ordem crescente dos números é:",A," -",B,"-",C 
SENÃO ESCREVA “A ordem crescente dos números é:",A," -",C,"-",B 
SE B<A E B<C 
ENTÃO SE A<C 
ENTÃO ESCREVA “A ordem crescente dos números é:",B,"-",A,"-",C 
SENÃO ESCREVA “A ordem crescente dos números é: “,B,"-",C,"-",A 
SE C<A E C<B 
ENTÃO SE A<B 
ENTÃO ESCREVA “A ordem crescente dos números é: “,C,"-",A,"-",B 
SENÃO ESCREVA “A ordem crescente dos números é: CC = eba = A 
FIM 
SE I=2 
ENTÃO INÍCIO 
SE A>B E A>C 
ENTÃO SE B>C 
ENTÃO ESCREVA “A ordem decrescente dos números é: “,A," -",B,"-",C 
SENÃO ESCREVA “A ordem decrescente dos números é: “,A,”" -",C,"-",B 
SE B>A E B>C 
ENTÃO SE A>C 
ENTÃO ESCREVA “A ordem decrescente dos números é: “,B," -",A,"-",C 
SENÃO ESCREVA “A ordem decrescente dos números é: “,B,”" -",C,"-",A 
SE C>A E C>B 
ENTÃO SE A>B 
ENTÃO ESCREVA “A ordem decrescente dos números é: “,C," -",A,"-",B 
SENÃO ESCREVA “A ordem decrescente dos números é: “,C," -",B,"-",A 
FIM 
SE 1=3 
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ENTÃO INÍCIO 
SE ADB E ADC 
ENTÃO ESCREVA “A ordem 
SE B>A E B>C 
ENTÃO ESCREVA “A ordem 
SE C>A E C>B 
ENTÃO ESCREVA “A ordem 
FIM 
FIM ALGORITMO. 


PASCAL 12 soLUÇÃO: 
D \EXERC\CAP4\PASCAL\EX7_A. PAS 


22 SOLUÇÃO: 
\EXERC\CAP4\PASCAL\EX7_B. PAS 


32 SOLUÇÃO: 
\EXERC\CAP4\PASCAL\EX7_C. PAS 


C/C++ 1º soLução: 
RE \EXERC\CAP4\C++\EX7_A.CPP e 


22 SOLUÇÃO: 
\EXERC\CAP4\C++\EX7_B.CPP e 
32 soLUÇÃO: 


\EXERC\CAP4\C++\EX7_C.CPP e 


JAVA A l? soLuçãÃo: 
GRE: VEXERCACAP4JAVANEX7 A.java 


22 SOLUÇÃO: 
VEXERCACAP4 JAVANEX7 B.java 


32 SOLUÇÃO: 
VEXERCACAP4NJAVANEX7 C.java 


desejada é: “,B,"-",A,"-",C 
desejada é: “,A,"-",B,"-",C 


desejada é: “,A,"-",C,"-",B 


e \EXERC\CAP4\PASCAL\EX7_A. EXE 


e \EXERC\CAP4\PASCAL\EX7_B.EXE 


e \EXERC\CAP4\PASCAL\EX7_C. EXE 


\EXERC\CAP4\C++\EX7_A. EXE 


\EXERC\CAP4\C++\EX7_B.EXE 


\EXERC\CAP4\C++\EX7_C. EXE 


e \EXERC\CAP4\JAVA\EX7_A.class 


e \EXERC\CAP4\JAVA\EX7_B.class 


e \EXERC\CAP4\JAVA\EX7_C.class 


EJ Faça um programa que mostre o menu de opções a seguir, receba a opção do usuário e os dados neces- 


sários para executar cada operação. 


Menu de opções: 
1. Somar dois números. 
2. Raiz quadrada de um número. 


Digite a opção desejada: 
SoLUÇÃO: 


ALGORITMO 


DECLARE numl, num2, soma, raiz, op NUMÉRICO 


ESCREVA “ MENU” 
ESCREVA “1- Somar dois números” 


ESCREVA “2- Raiz quadrada de um número” 


ESCREVA “Digite sua opção: ” 
LEIA op 
SE op = 1 

ENTÃO INÍCIO 


ESCREVA “Digite um valor para o primeiro número:” 


LEIA numl 
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ESCREVA “Digite um valor para o segundo número:” 
LEIA num2 
soma + numi + num2 
ESCREVA “A soma de “,numl,” e “,num2,” é “,soma 
FIM 
SE op = 2 
ENTÃO INÍCIO 
ESCREVA “Digite um valor: “ 
LEIA numl 
raiz — Vnumi 
ESCREVA “A raiz quadrada de “,numl,” é “,raiz 
FIM 
SE op * 1 E op*z 2 
ENTÃO ESCREVA “Opção inválida!” 
FIM ALGORITMO. 


PASCAL 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 


GEES VEXERCICAP4NPASCALNEX8 A.PAS e \EXERC\CAP4\PASCAL\EX8_A.EXE 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
VEXERCICAP4NPASCALNEX8 B.PAS e \EXERC\CAP4\PASCAL\EX8_B.EXE 
3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 
VEXERCICAP4NPASCALNEX8 C.PAS e \EXERC\CAP4\PASCAL\EX8_C.EXE 
1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
Cm] NEXERCNCAP4 \C++\EX8_A.CPP e \EXERC\CAP4\C++\EX8_A. EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
VEXERCACAP4NC++NEX8 B.CPP e \EXERC\CAP4\C++\EX8_B.EXE 
3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 
VEXERCACAP4NC++NEX8 C.CPP e \EXERC\CAP4\C++\EX8_C.EXE 
ie SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) \EXERC\CAP4\JAVA\EX8_A. java e \EXERC\CAP4\JAVA\EX8_A.class 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NJAVANEX8 B.java e \EXERC\CAP4\JAVA\EX8_B.class 


3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


VEXERCICAP4NJAVANEX8 C.java e NEXERCICAP4JAVANEX8 C.class 


BEAR Faça um programa que mostre a data e a hora do sistema nos seguintes formatos: DD/MM/AAAA — 
mês por extenso e hora:minuto. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 

DECLARE t, d, dia, mes, ano, hora, min NUMÉRICO 
d <— OBTENHA DATA; 

dia < OBTENHA DIA(d) 

mes < OBTENHA MÊS (d) 

ano < OBTENHA ANO(d) 


ESCREVA “Data Atual: 4 , dia, “/”", mes, “/", ano, “ —" 
SE mes = 1 

ENTÃO ESCREVA “janeiro” 
SE mes = 2 


ENTÃO ESCREVA “fevereiro” 
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SE mes = 3 

ENTÃO ESCREVA “março” 
SE mes = 4 

ENTÃO ESCREVA “abril” 
SE mes = 5 


ENTÃO ESCREVA “maio” 
SE mes = 6 

ENTÃO ESCREVA “junho” 
SE mes = 7 

ENTÃO ESCREVA “julho” 
SE mes = 8 

ENTÃO ESCREVA “agosto” 
SE mes = 9 

ENTÃO ESCREVA “setembro” 
SE mes = 10 

ENTÃO ESCREVA “outubro” 
SE mes = 11 

ENTÃO ESCREVA “novembro” 
SE mes = 12 

ENTÃO ESCREVA “dezembro” 
E = OBTENHA HORÁRIO; 
hora < OBTENHA HORA(t) 
min — OBTENHA MINUTO(t) 
ESCREVA “Hora Atual: “ 
ESCREVA hora, “:” , min 
FIM ALGORITMO. 


PANO NH SOLUÇÃO: 
D 


\EXERC\CAP4\PASCAL\EX9.PAS e \EXERC\CAP4\PASCAL\EX9 . EXE 


Na solução com a linguagem PASCAL, foram utilizados os comandos getdate e gettime, para obter 
a data e a hora do sistema operacional, respectivamente. O comando getdate retorna os valores do ano, 
mês, dia do mês e dia da semana da data do sistema operacional; as variáveis que receberão esses valores 
devem ser do tipo word. O comando gettime retorna os valores da hora, minuto, segundo e centésimo de 
segundo da hora do sistema operacional e as variáveis que receberão esses valores devem ser do tipo word. 
Para a utilização dos comandos getdate e gettime, é necessário utilizar a biblioteca DOS, ou seja, USES DOS. 


QOQ Observação 


O dia da semana é um número em que domingo vale 0; segunda-feira, 1; terça-feira, 2; quarta- 
-feira, 3; quinta-feira, 4; sexta-feira, 5; e sábado, 6. 
Exemplo: 


GETDATE (ano, mes, dia, dia_semana); 
GETTIME (hora, min, seg, cen_seg); 


eylen Ra SoLuçÃo: 
EE 
\EXERC\CAP4\C++\EX9.CPP e \EXERC\CAP4\C++\EX9 . EXE 


Na solução com a linguagem C/C++, foram utilizados os comandos t = time (NULL) e data hora 
localtime(&t) para obter a data e a hora do sistema operacional. Para a utilização desses comandos, 
necessário utilizar a biblioteca time.h, ou seja, tinclude <time.h> e a declaração do tipo time t. 


o Il 
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QO Q Observação 


Exemplo: 


time t t; 

struct tm *data hora; 

int dia, mes, ano, hora, min, seg; 
//Pega a data e a hora atual do sistema 
t = time(NULL); 

data hora = localtime(&t); 

dia = data hora -> tm mday; 

mes data hora -> tm mon + 1; 

ano = data hora -> tm year + 1900; 
hora = data hora -> tm hour; 

min = data hora -> tm min; 


// a declaração acima define um conjunto com 9 variáveis do tipo int. 

// as principais variáveis são: 

// tm sec - segundos da hora do sistema (0 a 59) 

// tm min - minutos da hora do sistema (0 a 59) 

// tm hour - horas da hora do sistema (0 a 23) 

// tm mday - dia da data do sistema (1 a 31) 

// tm mon - mês da data do sistema (0 a 11) 

// tm year - ano da data do sistema (desde 1900) 

// tm wday - dia da semana da data do sistema (0 a 6, sendo 0 o domingo) 


RANMA SoLução: 
To) 


VEXERCACAP4JAVANEX9. java e VEXERCICAP4JAVANEX9.class 


Na solução com a linguagem JAVA, foram utilizadas as classes Calendar e Date para empregar a data 
e a hora do sistema operacional. 


QQQ Observação 


Exemplo: 


int dia, mes, ano, hora, min; 
Calendar cal = Calendar.getInstance(); 
Date d = new Date(); 


cal.setTime(d); 

dia = cal.get(Calendar.DAY OF MONTH); 
mes = cal.get(Calendar.MONTH) + 1; 
ano = cal.get(Calendar.YEAR); 

hora = cal.get (Calendar. HOUR) ; 

min = cal.get(Calendar.MINUTE) ; 


ELA Faça um programa que determine a data cronologicamente maior entre duas datas fornecidas pelo 
usuário. Cada data deve ser composta por três valores inteiros, em que o primeiro representa o dia, o 
segundo, o mês e o terceiro, o ano. 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE dl,ml,al,d2,m2,a2 NUMÉRICO 
ESCREVA “Digite a primeira data” 
ESCREVA “ dia (dd): “ 


LEIA dl 

ESCREVA “ mês (mm): “ 
LEIA ml 

ESCREVA “ ano (aaaa): “ 
LEIA al 


ESCREVA “Digite a segunda data” 
ESCREVA “ dia (dd): “ 
LEIA d2 
ESCREVA “ mês (mm): “ 
LEIA m2 
ESCREVA “ ano (aaaa): “ 
LEIA a2 
SE al>a2 
ENTÃO ESCREVA “A maior data é: UOL a CASO Sd Ati A 
SENÃO SE a2>al 
ENTÃO ESCREVA “A maior data é: E (o PA MA VA A SED, 
SENÃO SE ml>m2 
ENTÃO ESCREVA “A maior data é: apal Id mi ÃO ML 
SENÃO SE m2>m1 


ENTÃO ESCREVA “A maior data é: “,d2, “-",m2,"-",a2 
SENÃO SE dl>d2 
ENTÃO ESCREVA “A maior data é: “-",dl,"-",ml,” -",al 
SENÃO SE d2>dl 
ENTÃO ESCREVA “A maior data é: “,d2,” -",m2,"-",a2 


SENÃO ESCREVA “As datas são iguais !” 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
CHEERS 
VEXERCACAP4NPASCALVEX10.PAS e VEXERCICAP4NPASCALNEX10.EXE 


eylen Ra SoLução: 
cE 
\EXERC\CAP4\C++\EX10.CPP e \EXERC\CAP4\C++\EX10.EXE 


RAIA SOLUÇÃO: 
E 
\EXERC\CAP4\JAVA\EX10.java e NEXERCICAP4JAVANEX10.class 


ELR Faça um programa que receba a hora do início de um jogo e a hora do término (cada hora é composta 
por duas variáveis inteiras: hora e minuto). Calcule e mostre a duração do jogo (horas e minutos), 
sabendo que o tempo máximo de duração do jogo é de 24 horas e que ele pode começar em um dia e 
terminar no dia seguinte. 


ALIRIM) Sorução: 


ALGORITMO 

DECLARE hora i, min i, hora f, min f£, hora d, min d NUMÉRICO 
ESCREVA “Digite o horário inicial” 

ESCREVA “hora: “” 

LEIA hora à 
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ESCREVA “minuto: “ 
LEIA min i 
ESCREVA “Digite o horário final “ 
ESCREVA “hora: ” 
LEIA hora f 
ESCREVA “minuto: “ 
LEIA min f 
SE min à > min f 
ENTÃO INÍCIO 
min f <— min f + 60 
hora £f <- hora f — 1 
FIM 
SE hora i > hora f 
ENTÃO hora f < hora £f + 24 
min d— min f - min i; 
hora d <— hora f - hora i; 
ESCREVA “O jogo durou “,hora d,” hora(s) e “,min d,” minuto(s)” 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
E 
\EXERC\CAP4\PASCAL\EX11.PAS e \EXERC\CAP4\PASCAL\EX11.EXE 


C/C++ E 
Do 
\EXERC\CAP4\C++\EX11.CPP e \EXERC\CAP4\C++\EX11.EXE 


JAVA A SoLuçÃo: 
D 
\EXERC\CAP4\JAVA\EX11.java e \EXERC\CAP4\JAVA\EX11.class 


EFA Faça um programa que receba o código correspondente ao cargo de um funcionário e seu salário atual 
e mostre o cargo, o valor do aumento e seu novo salário. Os cargos estão na tabela a seguir. 


CÓDIGO CARGO PERCENTUAL 
1 Escriturário 50% 
2 Secretário 35% 
3 Caixa 20% 
4 Gerente 10% 
5 Diretor Não tem aumento 


(ALLISIOJRNITIMO) Solução: 


ALGORITMO 
DECLARE salario, aumento, novo_sal, cargo NUMÉRICO 
ESCREVA “Digite o cargo do funcionário (1,2,3,4 ou 5)” 
LEIA cargo 
ESCREVA “Digite o valor do salário: ” 
LEIA salario 
SE cargo = 1 
ENTÃO INÍCIO 
ESCREVA “O cargo é Escriturário” 
aumento — salario * 50 / 100 
ESCREVA “O valor do aumento é: ”, aumento 
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novo sal < salario + aumento 
ESCREVA “O novo salário é: ”, novo sal 
FIM 
SENÃO SE cargo = 2 
ENTÃO INÍCIO 
ESCREVA “O cargo é Secretário” 
aumento + salario * 35 / 100 
ESCREVA “O valor do aumento é: ”, aumento 
novo sal — salario + aumento 
ESCREVA “O novo salário é: “, novo sal 
FIM 
SENÃO SE cargo = 3 
ENTÃO INÍCIO 
ESCREVA “O cargo é Caixa” 
aumento + salario * 20 / 100 


ESCREVA “O valor do aumento é: “”, aumento 
novo sal < salario + aumento 

ESCREVA “O novo salário é: “,novo sal 

FIM 


SENÃO SE cargo = 4 
ENTÃO INÍCIO 
ESCREVA “O cargo é Gerente” 
aumento + salario * 10 / 100 
ESCREVA “O valor do aumento é: ”, aumento 
novo sal < salario + aumento 
ESCREVA “O novo salário é: “, novo sal 
FIM 
SENÃO SE cargo = 5 
ENTÃO INÍCIO 
ESCREVA “O cargo é Diretor” 
aumento + salario * 0 / 100 
ESCREVA “O valor do aumento é: “, aumento 
novo sal — salario + aumento 
ESCREVA “O novo salário é: “, novo sal 
FIM 
SENÃO ESCREVA “Cargo Inexistente !” 
FIM ALGORITMO. 


PASCAL tz SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
ERR VEXERCICAP4NPASCALNEX12 A.PAS e NEXERCICAP4NPASCALNEX12 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


VEXERCICAP4NPASCALNEX12 B.PAS e NEXERCICAP4NPASCALNEX12 B.EXE 
ePAeR ZUM 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
VEXERCACAP4NC++NEX12 A.CPP e \EXERC\CAP4\C++\EX12_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


VEXERCACAP4NC++NEX12 B.CPP e \EXERC\CAP4\C++\EX12_B.EXE 
JAVA 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
D \EXERC\CAP4\JAVA\EX12_A.java e \EXERC\CAP4\JAVA\EX12_A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


VEXERCICAP4NJAVANEX12 B.java e NEXERCICAP4JAVANEX12 B.class 
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EEA Faça um programa que apresente o menu a seguir, permita ao usuário escolher a opção desejada, re- 
ceba os dados necessários para executar a operação e mostre o resultado. Verifique a possibilidade de 
opção inválida e não se preocupe com restrições, como salário negativo. 


Menu de opções: 
1. Imposto 

2. Novo salário 
3. Classificação 


Digite a opção desejada. 


Na opção 1: receber o salário de um funcionário, calcular e mostrar o valor do imposto usando as regras 
a seguir. 


SALÁRIO PERCENTUAL DO IMPOSTO 
Menor que R$ 500,00 5% 
De R$ 500,00 (inclusive) a R$ 850,00 (inclusive) 10% 
Acima de R$ 850,00 15% 


Na opção 2: receber o salário de um funcionário, calcular e mostrar o valor do novo salário, usando as 
regras a seguir. 


SALÁRIO AUMENTO 
Maior que R$ 1.500,00 R$ 25,00 
De R$ 750,00 (inclusive) a R$ 1.500,00 (inclusive) R$ 50,00 
De R$ 450,00 (inclusive) a R$ 750,00 R$ 75,00 
Menor que R$ 450,00 R$ 100,00 


Na opção 3: receber o salário de um funcionário e mostrar sua classificação usando a tabela a seguir. 


SALÁRIO CLASSIFICAÇÃO 
Até R$ 700,00 (inclusive) Mal remunerado 
Maiores que R$ 700,00 Bem remunerado 


(ALLTSIOJEL TIM) Solução: 


ALGORITMO 
DECLARE op, sal, imp, aum, novo sal NUMÉRICO 
ESCREVA “MENU DE OPÇÕES” 
ESCREVA “1 — IMPOSTO” 
ESCREVA “NOVO SALÁRIO” 
ESCREVA “CLASSIFICAÇÃO” 
ESCREVA “DIGITE A OPÇÃO DESEJADA” 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
LEIA sal 
SE sal < 500 
ENTÃO imp — sal * 5/100 
SE sal >= 500 E sal <= 850 
ENTÃO imp — sal * 10/100 
SE sal > 850 
ENTÃO imp — sal * 15/100 
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ESCREVA imp 
FIM 
SE op = 2 
ENTÃO INÍCIO 
LEIA sal 
SE sal > 1500 
ENTÃO aum — 25 
SE sal >= 750 E sal <= 1500 
ENTÃO aum — 50 
SE sal >= 450 E sal < 750 
ENTÃO aum — 75 
SE sal < 450 
ENTÃO aum + 100 novo sal + sal + aum 
ESCREVA novo sal 
FIM 
SE op = 3 
ENTÃO INÍCIO 
LEIA sal 
SE sal <= 700 
ENTÃO ESCREVA"Mal Remunerado” 
SE sal > 700 
ENTÃO ESCREVA"Bem Remunerado” 
FIM 
SE op < 1 OU op > 3 
ENTÃO ESCREVA “Opção Inválida” 
FIM ALGORITMO. 


INS NAM 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
D EXERC \CAP4\PASCAL\EX1 3_A.PAS e \EXERC\CAP4\PASCAL\EX1 3 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NPASCALNEX13 B.PAS e NEXERCICAP4NPASCALNEX13 B.EXE 


3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


NEXERCICAP4NPASCALNEX13 C.PAS e NEXERCICAP4NPASCALNEX13 C.EXE 
1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) VEXERCNCAP4ANC++NEX13 A.CPP e \EXERC\CAP4\C++\EX13_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


\EXERC\CAP4\C++\EX13_B.CPP e \EXERC\CAP4\C++\EX13_B.EXE 


32 SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


\EXERC\CAP4\C++\EX13_C.CPP e \EXERC\CAP4\C++\EX13_C.EXE 
JAVA ta SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
EXERCÍCAP4 JAVANEX13 A.java e NEXERCICAP4 JAVANEX13 A.class 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


NEXERCACAP4NJAVANEX13 B.java e NEXERCACAP4JAVANEX13 B.class 


3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


NEXERCACAP4NJAVANEX13 C.java e NEXERCACAP4JAVANEX13 C.class 
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ELA Faça um programa que receba o salário inicial de um funcionário, calcule e mostre o novo salário, 
acrescido de bonificação e de auxílio escola. 


SALÁRIO BONIFICAÇÃO SALÁRIO AUXÍLIO ESCOLA 
Até R$ 500,00 5% do salário Até R$ 600,00 R$ 150,00 
Entre R$ 500,00 e R$ 1.200,00 12% do salário Acima de R$ 600,00 R$ 100,00 
Acima de R$ 1.200,00 Sem bonificação 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE sal, novo sal, boni, aux NUMÉRICO 
LEIA sal 
SE sal <= 500 
ENTÃO boni <— sal * 5/100 
SENÃO SE sal <= 1200 
ENTÃO boni + sal * 12/100 
SENÃO boni <— 0 
SE sal <= 600 
ENTÃO aux <— 150 
SENÃO aux < 100 
novo sal <- sal + boni + aux 
ESCREVA novo sal 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
ed) NEXERCNCAP4 VPASCALVEX14 A.PAS e NEXERCÍCAP4NPASCALNEX14 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NPASCALNEX14 B.PAS e NEXERCICAP4NPASCALNEX14 B.EXE 


ePAeR TTA 1º SoLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 


VEXERCACAP4NC++NEX14 A.CPP e \EXERC\CAP4\C++\EX14_A.EXE 


VEXERCACAP4NC++NEX14 B.CPP e \EXERC\CAP4\C++\EX14_B.EXE 


JAVA 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NJAVANEX14 A.java e NEXERCICAP4JAVANEX14 A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NJAVANEX14 B.java e NEXERCICAP4JAVANEX14 B.class 


HA Faça um programa que receba o valor do salário mínimo, o número de horas trabalhadas, o número 
de dependentes do funcionário e a quantidade de horas extras trabalhadas. Calcule e mostre o salário 
a receber do funcionário de acordo com as regras a seguir: 
O valor da hora trabalhada é igual a 1/5 do salário mínimo. 


O salário do mês é igual ao número de horas trabalhadas multiplicado pelo valor da hora traba- 
lhada. 


Para cada dependente, acrescentar R$ 32,00. 
Para cada hora extra trabalhada, calcular o valor da hora trabalhada acrescida de 50%. 


O salário bruto é igual ao salário do mês mais o valor dos dependentes mais o valor das horas 
extras. 


Calcular o valor do imposto de renda retido na fonte de acordo com a tabela a seguir: 
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IRRF SALÁRIO BRUTO 
Isento Inferior a R$ 200,00 

10% De R$ 200,00 até R$ 500,00 
20% Superior a R$ 500,00 


O salário líquido é igual ao salário bruto menos IRRF. 
A gratificação é de acordo com a tabela a seguir: 


SALÁRIO LÍQUIDO GRATIFICAÇÃO 
Até R$ 350,00 R$ 100,00 
Superior a R$ 350,00 R$ 50,00 


O salário a receber do funcionário é igual ao salário líquido mais a gratificação. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE sal min, nht, ndep, nhet NUMÉRICO 
sal receber, vh, smes, vdep, vhe, imp NUMÉRICO 
sbruto, sliq, grat NUMÉRICO 
LEIA sal min, nht, ndep, nhet 
vh + 1/5 * sal min 
smes — nht * vh 
vdep <— 32 * ndep 
vhe < nhet * (vh + (vh * 50/100)) 
sbruto +— smes + vdep + vhe 
SE sbruto < 200 
ENTÃO imp — 0 
SE sbruto >= 200 E sbruto <= 500 
ENTÃO imp — sbruto * 10/100 
SE sbruto > 500 
ENTÃO imp — sbruto * 20/100 
sliq + sbruto — imp 
SE sliq <= 350 
ENTÃO grat <— 100 
SE sliq > 350 
ENTÃO grat — 50 
sal receber +— sliq + grat 
ESCREVA sal receber 
FIM ALGORITMO. 


PASCAL 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 


D \EXERC\CAP4\PASCAL\EX15_A.PAS e \EXERC\CAP4\PASCAL\EX15_A.EXE 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


\EXERC\CAP4\PASCAL\EX15_B.PAS e \EXERC\CAP4\PASCAL\EX15_B.EXE 


Ple TEA 1º SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) \EXERC\CAP4\C++\EX15_A.CPP e \EXERC\CAP4\C++\EX15_A.EXE 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NC++NEX15 B.CPP e \EXERC\CAP4\C++\EX15_B.EXE 
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JAVA 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
ed) NEXERCNCAP4 NJAVANEX15 A.java e \EXERC\CAP4\JAVA\EX15_A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


NEXERCACAP4NJAVANEX15 B.java e \EXERC\CAP4\JAVA\EX15_B.class 


HA Um supermercado deseja reajustar os preços de seus produtos usando o seguinte critério: o produto 
poderá ter seu preço aumentado ou diminuído. Para o preço ser alterado, o produto deve preencher 
pelo menos um dos requisitos a seguir: 


VENDA MÉDIA MENSAL PREÇO ATUAL % DE AUMENTO % DE DIMINUIÇÃO 
< 500 < R$ 30,00 10 — 
>= 500 e< 1.200 >= R$ 30,00 e < R$ 80,00 15 — 
>= 1.200 >= R$ 80,00 = 20 


Faça um programa que receba o preço atual e a venda média mensal do produto, calcule e mostre o 
novo preço. 


(ALLTSIOJEN ITIMO) Solução: 


ALGORITMO 
DECLARE pre, venda, novo pre NUMÉRICO 
LEIA pre, venda 
SE venda<500 OU pre<30 
ENTÃO novo pre <— pre + 10/100 * pre 
SENÃO SE (venda>=500 E venda<1200) OU (pre>=30 E pre<80) 
ENTÃO novo pre <— pre + 15/100 * pre 
SENÃO SE venda>=1200 OU pre>=80 
ENTÃO novo pre — pre — 20/100 * pre 
ESCREVA novo pre 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
EES 
NEXERCACAP4NPASCALVEX16.PAS e VEXERCICAP4NPASCALNEX16.EXE 


C/C++ Sorução: 
GER 
\EXERC\CAP4\C++\EX16.CPP e NEXERCACAP4NC++NEX16. EXE 


RANMA SoLução: 
(2e SS) 
\EXERC\CAP4\JAVA\EX16.java e NEXERCICAP4JAVANEX16.class 


EFA Faça um programa para resolver equações do 2º grau. 


ax + bx+c=0 

A variável a deve ser diferente de zero. 
A=b? -4+:a+c 

A < O — não existe raiz real 

A = 0 — existe uma raiz real 

x= (—b)/ (2 + a) 

A > 0 — existem duas raízes reais 

x1 = (—b + YA) (2 + a) 

x2 = (—b — }A)/ (2 * a) 
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(AJLIGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE a, b, c, delta, xl, x2 NUMÉRICO 
LEIA a, b, c 
SE a = 0 
ENTÃO ESCREVA “Estes valores não formam uma equação de segundo grau” 
SENÃO INÍCIO 
delta <— (b *b) —- (4 *a*c) 
SE delta < 0 
ENTÃO ESCREVA “Não existe raiz real” 
SE delta = 0 
ENTÃO INÍCIO 
ESCREVA “Existe uma raiz real” 
xl + (>b) / (2 *a) 
ESCREVA x1 
FIM 
SE delta > 0 
ENTÃO INÍCIO 
ESCREVA “Existem duas raízes reais” 
sell, «== e o delta) PO ES EN) 
SRD = (Ep Ceres) RO o a) 
ESCREVA x1, x2 
FIM 
FIM 
FIM_ALGORITMO. 


PASCAL SoLUÇÃO: 


\EXERC\CAP4\PASCAL\EX17.PAS e \EXERC\CAP4\PASCAL\EX17.EXE 


CVETA Solução: 
GEES 


\EXERC\CAP4\C++\EX17.CPP e \EXERC\CAP4\C++\EX17.EXE 
NWA SoLução: 


\EXERC\CAP4\JAVA\EX17.java e NEXERCICAP4JAVANEX17.class 


EEJ Dados três valores X, Y e Z, verifique se eles podem ser os comprimentos dos lados de um triângulo 
e, se forem, verifique se é um triângulo equilátero, isósceles ou escaleno. Se eles não formarem um 
triângulo, escreva uma mensagem. Considere que: 

o comprimento de cada lado de um triângulo é menor que a soma dos outros dois lados; 
chama-se equilátero o triângulo que tem três lados iguais; 
denomina-se isósceles o triângulo que tem o comprimento de dois lados iguais; 


recebe o nome de escaleno o triângulo que tem os três lados diferentes. 
ALIRIM) Sorução: 


ALGORITMO 
DECLARE x, Y, Z NUMÉRICO 
LEIA x, Y, Z 
SM dé CS Sm DA dm NS Sie ap bg JD) DA O de np da 
ENTÃO INÍCIO 
SE x=y Ey=az 
ENTÃO ESCREVA “Triângulo Equilátero” 
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SENÃO SE x = y OU x = z OU y=z 
ENTÃO ESCREVA “Triângulo Isósceles” 
SENÃO SE x *=y Ex *zEy az 


ENTÃO ESCREVA “Triângulo Escaleno” 
FIM 


SENÃO ESCREVA “Essas medidas não formam um triângulo” 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 


VEXERCACAP4NPASCALNVEX18.PAS e VEXERCICAP4NPASCALNEX18.EXE 


C/c++ ENNIO 
[ES] 


\EXERC\CAP4\C++\EX18.CPP e NEXERCACAP4NC++NEX18. EXE 


E-Go- SoLução: 
GEES 


\EXERC\CAP4\JAVA\EX18.java e NEXERCICAP4JAVANEX18.class 


EL] Faça um programa que receba a altura e o peso de uma pessoa. De acordo com a tabela a seguir, veri- 
fique e mostre a classificação dessa pessoa. 


PESO 
ALTURA E 
ATE 60 ENTRE 60 E 90 (INCLUSIVE) ACIMA DE 90 
Menores que 1,20 A D G 
De 1,20 a 1,70 B E H 
Maiores que 1,70 C F | 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE altura, peso NUMÉRICO 
LEIA altura, peso 
SE altura < 1.20 
ENTÃO INÍCIO 
SE peso <= 60 
ENTÃO ESCREVA “A” 
SE peso > 60 E peso <= 90 
ENTÃO ESCREVA “D” 
SE peso > 90 
ENTÃO ESCREVA “G” 
FIM 
SE altura >= 1.20 E altura <= 1.70 
ENTÃO INÍCIO 
SE peso <= 60 
ENTÃO ESCREVA “B” 
SE peso > 60 E peso <= 90 
ENTÃO ESCREVA “E” 
SE peso > 90 
ENTÃO ESCREVA “H” 
FIM 
SE altura > 1.70 
ENTÃO INÍCIO 
SE peso <= 60 
ENTÃO ESCREVA “C” 
SE peso > 60 E peso <= 90 
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ENTÃO ESCREVA “F” 
SE peso > 90 

ENTÃO ESCREVA “I” 
FIM 


FIM ALGORITMO. 


iJaNSeJaV 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
D \EXERC\CAP4\PASCAL\EX19_A.PAS e NEXERCICAP4NPASCALNEX19 A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCICAP4NPASCALNEX19 B.PAS e NEXERCICAP4NPASCALNEX19 B.EXE 


C/C++ 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
e) \EXERC\CAP4\C++\EX19_A.CPP e \EXERC\CAP4\C++\EX19_A.EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


\EXERC\CAP4\C++\EX19_B.CPP e \EXERC\CAP4\C++\EX19_B.EXE 


JAVA 12 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
ad) VEXERC NCAP4NJAVANEX19 A.java e VEXERCICAP4NJAVANEX19 A.class 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NJAVANEXI9 B.java e NEXERCICAP4JAVANEX19 B.class 


ETH Faça um programa que receba: 


O código de um produto comprado, supondo que a digitação do código do produto seja sempre 
válida, isto é, um número inteiro entre 1 e 10. 


O peso do produto em quilos. 


O código do país de origem, supondo que a digitação do código seja sempre válida, isto é, um nú- 
mero inteiro entre 1 e 3. 


Tabelas: 
CÓDIGO DO PAÍS CÓDIGO DO PREÇO POR 
DE ORIGEM IMROSTO PRODUTO GRAMA 
1 0% la4 10 
15% 5a7 25 
25% 8a 10 35 


Calcule e mostre: 
o peso do produto convertido em gramas; 
o preço total do produto comprado; 


o valor do imposto, sabendo que ele é cobrado sobre o preço total do produto comprado e depende 
do país de origem; 


o valor total, preço total do produto mais imposto. 


ALIRIM) Sorução: 


ALGORITMO 

DECLARE cod prod, peso quilos NUMÉRICO 
cod pais, peso gramas, pre total NUMÉRICO 
imposto, valor total, pre grama NUMÉRICO 

LEIA cod prod, peso quilos, cod pais 

peso gramas + peso quilos * 1000 

ESCREVA peso gramas 

SE cod prod >= 1 E cod prod <= 4 
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ENTÃO pre grama — 10 
SE cod prod >= 5 E cod prod <= 
ENTÃO pre grama — 25 
SE cod prod >= 8 E cod prod <= 
ENTÃO pre grama — 35 
pre total < peso gramas * pre grama 
ESCREVA pre total 


SE cod pais 


1 


ENTÃO imposto — 0 


SE cod pais 


2 


10 


ENTÃO imposto <— pre total * 15/100 


SE cod pais 


3 


ENTÃO imposto <— pre total * 25/100 
ESCREVA imposto 
valor total <- pre total + imposto 
ESCREVA valor total 
FIM ALGORITMO. 


PASCAL 
D 


C/C++ 
CEE 


JAVA 
D 


12 SOLUÇÃO — UTILIZANDO ESTR 
\EXERC\CAP4\PASCAL\E 
22 SOLUÇÃO — UTILIZANDO ESTR 
NEXERCACAP4NPASCALNE 
32 SOLUÇÃO — UTILIZANDO ESTR 
\EXERC\CAP4\PASCAL\E 
12 SOLUÇÃO — UTILIZANDO ESTR 
\EXERC\CAP4\C++\EX20 
22 SOLUÇÃO — UTILIZANDO ESTR 
\EXERC\CAP4\C++\EX20 
32 SOLUÇÃO — UTILIZANDO ESTR 
\EXERC\CAP4\C++\EX20 
12 SOLUÇÃO — UTILIZANDO ESTR 
EXERC\CAP4\JAVA\EX20 
22 SOLUÇÃO — UTILIZANDO EST 

\EXERC\CAP4\JAVA\EX2 
32 SOLUÇÃO — UTILIZANDO ESTI 


RUT 


RUT 


TURA CONDICIONAL SIMPLES: 


O A.PAS e \EXERC\CAP4\PASCAL\EX20_A. EXE 


TURA CONDICIONAL COMPOSTA: 


O B.PAS e NEXERCÂCAP4NPASCALNEX20 B.EXE 


TURA SELETORA: 


O C.PAS e NEXERCÂCAP4NPASCALNEX20 C.EXE 


TURA CONDICIONAL SIMPLES: 


«CPP e \EXERC\CAP4\C++\EX20_A.EXE 


TURA CONDICIONAL COMPOSTA: 


«CPP e \EXERC\CAP4\C++\EX20_B.EXE 


TURA SELETORA: 


«CPP e \EXERC\CAP4\C++\EX20_C.EXE 


TURA CONDICIONAL SIMPLES: 


«java e NEXERCACAP4NJAVANEX20 A.class 


RA CONDICIONAL COMPOSTA: 


 B.java e NEXERCICAP4JAVANEX20 B.class 


RA SELETORA: 


NEXERCACAP4NJAVANEX20 C.java e NEXERCACAP4NJAVANEX20 C.class 


PR Faça um programa que receba: 


o código do estado de origem da carga de um caminhão, supondo que a digitação do código do 
estado seja sempre válida, isto é, um número inteiro entre 1 e 5; 


o peso da carga do caminhão em toneladas; 


o código da carga, supondo que a digitação do código seja sempre válida, isto é, um número inteiro 
entre 10 e 40. 
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Tabelas: 
CÓDIGO DO ESTADO IMPOSTO CÓDIGO DA CARGA PREÇO POR QUILO 
1 35% 10 a 20 100 
2 25% 21a 30 250 
3 15% 31240 340 
4 5% 
5 Isento 


Calcule e mostre: 
o peso da carga do caminhão convertido em quilos; 
o preço da carga do caminhão; 


o valor do imposto, sabendo que o imposto é cobrado sobre o preço da carga do caminhão e de- 
pende do estado de origem; 


o valor total transportado pelo caminhão, preço da carga mais imposto. 


(AILTSIOJRI ITIMO) Solução: 


ALGORITMO 
DECLARE cod est, cod carga, peso toneladas NUMÉRICO 

peso quilos, pre carga, imposto, valor total NUMÉRICO 
LEIA cod est, peso toneladas, cod carga 
peso quilos < peso toneladas * 1000 
ESCREVA peso quilos 
SE cod carga >= 10 E cod carga <= 20 

ENTÃO pre carga + 100 * peso quilos 
SE cod carga >= 21 E cod carga <= 30 

ENTÃO pre carga + 250 * peso quilos 
SE cod carga >= 31 E cod carga <= 40 

ENTÃO pre carga + 340 * peso quilos 
ESCREVA pre carga 
SE cod est = 1 

ENTÃO imposto <— 35/100 * pre carga 
SE cod est = 2 

ENTÃO imposto — 25/100 * pre carga 
SE cod est = 3 

ENTÃO imposto <— 15/100 * pre carga 
SE cod est = 4 

ENTÃO imposto — 5/100 * pre carga 
SE cod est = 5 

ENTÃO imposto — 0 
ESCREVA imposto 
valor total — pre carga + imposto 
ESCREVA valor total 
FIM ALGORITMO. 


PASCAL 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 

e) VEXERCNCAP4NPASCALNEX2 1 A.PAS e \EXERC\CAP4\PASCAL\EX21_A. EXE 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 
VEXERCICAP4NPASCALNEX21 B.PAS e NEXERCICAP4NPASCALNEX21 B.EXE 
32 SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


VEXERCICAP4NPASCALNEX21 C.PAS e NEXERCICAP4NPASCALNEX21 C.EXE 
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eyle E 1º SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
ea) \EXERC\CAP4\C++\EX21_A.CPP e \EXERC\CAP4\C++\EX2 1_A.EXE 


22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


VEXERCACAP4NC++NEX21 B.CPP e \EXERC\CAP4\C++\EX21_B.EXE 


3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


VEXERCACAP4NC++NEX21 C.CPP e \EXERC\CAP4\C++\EX21_C.EXE 
JAVA 1a SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL SIMPLES: 
NEXERCACAP4NJAVANEX21 A.java e VEXERCICAP4JAVANEX21 A.class 
22 SOLUÇÃO — UTILIZANDO ESTRUTURA CONDICIONAL COMPOSTA: 


\EXERC\CAP4\JAVA\EX21_B.java e \EXERC\CAP4\JAVA\EX21_B.class 


3a SOLUÇÃO — UTILIZANDO ESTRUTURA SELETORA: 


NEXERCACAP4NJAVANEX21 C.java e NEXERCICAP4NJAVANEX21 C.class 


EFA Faça um programa que receba o salário base e o tempo de serviço de um funcionário. Calcule e mostre: 
O imposto, conforme a tabela a seguir. 


SALÁRIO BASE % SOBRE O SALÁRIO BASE 
< R$ 200,00 isento 
Entre R$ 200,00 (inclusive) e R$ 450,00 (inclusive) 3% 
Entre R$ 450,00 e R$ 700,00 8% 
>= R$ 700,00 12% 


A gratificação, de acordo com a tabela a seguir. 


TEMPO DE 


ALÁRIO BASE RATIFICAÇÃI 
S OBAS SERVIÇO € CACAO 

f Até 3 anos 20 
Superior a R$ 500,00 

Mais de 3 anos 30 

Até 3 anos 23 

Até R$ 500,00 Entre 3 e 6 anos 35 

De 6 anos para cima 33 


O salário líquido, ou seja, salário base menos imposto mais gratificação. 
A categoria, que está na tabela a seguir. 


SALÁRIO LÍQUIDO CLASSIFICAÇÃO 
Até R$ 350,00 A 
Entre R$ 350,00 e R$ 600,00 B 
De R$ 600,00 para cima € 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE sal base, tempo, imposto, grat NUMÉRICO 
sal liq NUMÉRICO 

LEIA sal base, tempo 

SE sal base < 200 
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ENTÃO imposto — 0 
SENÃO SE sal base <= 450 
ENTÃO imposto — 3/100 * sal base 
SENÃO SE sal base < 700 
ENTÃO imposto — 8/100 * sal base 
SENÃO imposto + 12/100 * sal base 
ESCREVA imposto 
SE sal base > 500 
ENTÃO INÍCIO 
SE tempo <= 3 
ENTÃO grat — 20 
SENÃO grat — 30 
FIM 
SENÃO INÍCIO 
SE tempo <= 3 
ENTÃO grat — 23 
SENÃO SE tempo < 6 
ENTÃO grat — 35 
SENÃO grat — 33 
FIM 
ESCREVA grat 
sal liq « sal base — imposto + grat 
ESCREVA sal lig 
SE sal liq <= 350 
ENTÃO ESCREVA “Classificação A” 
SENÃO SE sal ligq < 600 
ENTÃO ESCREVA “Classificação B” 
SENÃO ESCREVA “Classificação C” 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
ES 
VEXERCACAP4NPASCALVEX22.PAS e NVEXERCACAP4NPASCALNEX22.EXE 


PARRA SoLução: 
GEES 


\EXERC\CAP4\C++\EX22.CPP e NEXERCACAP4NC++NEX22. EXE 
RB WIAN SoLução: 


\EXERC\CAP4\JAVA\EX22.java e NEXERCICAP4JAVANEX22.class 


FER Faça um programa que receba o valor do salário mínimo, o turno de trabalho (M — matutino; V 
— vespertino; ou N — noturno), a categoria (O — operário; G — gerente) e o número de horas tra- 
balhadas no mês de um funcionário. Suponha a digitação apenas de dados válidos e, quando houver 
digitação de letras, utilize maiúsculas. Calcule e mostre: 


O coeficiente do salário, de acordo com a tabela a seguir. 


TURNO DE TRABALHO VALOR DO COEFICIENTE 
M — Matutino 10% do salário mínimo 
V — Vespertino 15% do salário mínimo 
N — Noturno 12% do salário mínimo 


O valor do salário bruto, ou seja, o número de horas trabalhadas multiplicado pelo valor do coe- 
ficiente do salário. 


O imposto, de acordo com a tabela a seguir. 
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CATEGORIA SALÁRIO BRUTO IMPOSTO SOBRE O SALÁRIO BRUTO 
pi >= R$ 300,00 5% 
O — Operário 
< R$ 300,00 3% 
>= R$ 400,00 6% 
G — Gerente 
< R$ 400,00 4% 


A gratificação, de acordo com as regras a seguir. 
Se o funcionário preencher todos os requisitos a seguir, sua gratificação será de 
R$ 50,00; caso contrário, será de R$ 30,00. Os requisitos são: 
Turno: Noturno 
Número de horas trabalhadas: Superior a 80 horas 
O auxílio alimentação, de acordo com as seguintes regras. 
Se o funcionário preencher algum dos requisitos a seguir, seu auxílio alimentação será de um terço 
do seu salário bruto; caso contrário, será de metade do seu salário bruto. Os requisitos são: 
Categoria: Operário 
Coeficiente do salário: < = 25 
O salário líquido, ou seja, salário bruto menos imposto mais gratificação mais auxílio alimentação. 


A classificação, de acordo com a tabela a seguir: 


SALÁRIO LÍQUIDO MENSAGEM 
Menor que R$ 350,00 Mal remunerado 
Entre R$ 350,00 e R$ 600,00 Normal 
Maior que R$ 600,00 Bem remunerado 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE sal min, nht, coeficiente, sal bruto NUMÉRICO 
imposto, grat, auxilio, sal liqg NUMÉRICO 
turno, categoria LITERAL 
LEIA sal min, turno, categoria, nht 
SE turno = “M” 
ENTÃO coeficiente — 10/100 * sal min 
SE turno = “V” 
ENTÃO coeficiente — 15/100 * sal min 
SE turno = “N” 
ENTÃO coeficiente — 12/100 * sal min 
ESCREVA coeficiente 
sal bruto + nht * coeficiente 
ESCREVA sal bruto 
SE categoria = “0” 
ENTÃO INÍCIO 
SE sal bruto >= 300 
ENTÃO imposto — 5/100 * sal bruto 
SENÃO imposto — 3/100 * sal bruto 
FIM 
SENÃO INÍCIO 
SE sal bruto >= 400 
ENTÃO imposto — 6/100 * sal bruto 
SENÃO imposto — 4/100 * sal bruto 
FIM 
ESCREVA imposto 
SE turno = “N” E nht > 80 
ENTÃO grat — 50 
SENÃO grat <— 30 
ESCREVA grat 
SE categoria = “0” OU coeficiente <= 25 
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ENTÃO auxilio — 1/3 * sal bruto 
SENÃO auxilio — 1/2 * sal bruto 
ESCREVA auxilio 
sal liq — sal bruto — imposto + grat + auxilio 
ESCREVA sal lig 
SE sal lig < 350 
ENTÃO ESCREVA “Mal Remunerado” 
SE sal lig >= 350 E sal lig <= 600 
ENTÃO ESCREVA “Normal” 
SE sal lig > 600 
ENTÃO ESCREVA “Bem Remunerado” 
FIM ALGORITMO. 


PASCAL SoLUÇÃO: 
GE 
VEXERCACAP4NPASCALVEX23.PAS e VEXERCICAP4NPASCALNEX23.EXE 


C/C++ [SURTO 
\EXERC\CAP4\C++\EX23.CPP e NEXERCACAP4NC++NEX23. EXE 


RB WIAN SoLução: 
[=] 


\EXERC\CAP4\JAVA\EX23.java e NEXERCICAP4JAVANEX23.class 
ELZA Faça um programa que receba o preço, o tipo (A — alimentação; L — limpeza; e V — vestuário) e a 
refrigeração (S — produto que necessita de refrigeração; e N — produto que não necessita de refri- 


geração) de um produto. Suponha que haverá apenas a digitação de dados válidos e, quando houver 
digitação de letras, utilize maiúsculas. Calcule e mostre: 


O valor adicional, de acordo com a tabela a seguir: 


REFRIGERAÇÃO TIPO PREÇO VALOR ADICIONAL 
A < R$ 15,00 R$ 2,00 
>= R$ 15,00 R$ 5,00 
< R$ 10,00 R$ 1,50 
N L 
>= R$ 10,00 R$ 2,50 
ý < R$ 30,00 R$ 3,00 
>= R$ 30,00 R$ 2,50 
A R$ 8,00 
S L R$ 0,00 
V R$ 0,00 


O valor do imposto, de acordo com a regra a seguir. 


PREÇO PERCENTUAL SOBRE O PREÇO 
< R$ 25,00 5% 
>= R$ 25,00 8% 


O preço de custo, ou seja, preço mais imposto. 
O desconto, de acordo com a regra a seguir. 
O produto que não preencher nenhum dos requisitos a seguir terá desconto de 3%, caso contrário, 
O (zero). 
Os requisitos são: 
Tipo: A 
Refrigeração: S 
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O novo preço, ou seja, preço de custo mais adicional menos desconto. 
A classificação, de acordo com a regra a seguir. 


NOVO PREÇO CLASSIFICAÇÃO 

<= R$ 50,00 Barato 
Entre R$ 50,00 e R$ 100,00 Normal 

>= R$ 100,00 Caro 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE pre, valor adic, imposto NUMÉRICO 
pre custo, desconto, novo pre NUMÉRICO 
tipo, refrig LITERAL 
LEIA pre, tipo, refrig 
SE refrig = “N” 
ENTÃO INÍCIO 
SE tipo = “A” 
ENTÃO INÍCIO 
SE pre < 15 
ENTÃO valor adic 
SENÃO valor adic 


î Î 


FIM 
SE tipo = “L” 
ENTÃO INÍCIO 
SE pre < 10 
ENTÃO valor adic — 1,50 
SENÃO valor adic — 2,50 
FIM 
SE tipo = “V” 
ENTÃO INÍCIO 
SE pre < 30 
ENTÃO valor adic — 3 
SENÃO valor adic — 2,5 
FIM 
FIM 
SENÃO INÍCIO 
SE tipo = “A” 
ENTÃO valor adic — 8 
SE tipo = “L” 
ENTÃO valor adic + 0 
SE tipo = “V” 
ENTÃO valor adic + 0 
FIM 
ESCREVA valor adic 
SE pre < 25 
ENTÃO imposto — 5/100 * pré 
SENÃO imposto — 8/100 * pre 
ESCREVA imposto 
pre custo <— pre + imposto 
ESCREVA pre custo 
SE tipo #4 <A% E refrig 4 «S7 
ENTÃO desconto — 3/100 * pre custo 
SENÃO desconto — 0 
ESCREVA desconto 
novo pre « pre custo + valor adic — desconto 
ESCREVA novo pre 
SE novo pre <= 50 
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ENTÃO ESCREVA “Barato” 
SENÃO SE novo pre < 100 
ENTÃO ESCREVA “Normal” 
SENÃO ESCREVA “Caro” 
FIM ALGORITMO. 


PINNA SOLUÇÃO: 
ea 


\EXERC\CAP4\PASCAL\EX24.PAS e \EXERC\CAP4\PASCAL\EX24.EXE 


eylen Ra SoLuçÃo: 
C 


\EXERC\CAP4\C++\EX24.CPP e \EXERC\CAP4\C++\EX24.EXE 


SEGS SoLução: 
D 


\EXERC\CAP4\JAVA\EX24.java e \EXERC\CAP4\JAVA\EX24.class 


FER Faça um programa que receba a medida de um ângulo em graus. Calcule e mostre o quadrante em que 
se localiza esse ângulo. Considere os quadrantes da trigonometria e, para ângulos maiores que 360º ou 
menores que -360º, reduzi-los, mostrando também o número de voltas e o sentido da volta (horário 
ou anti-horário). 


(AILIGIOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE angulo, voltas NUMÉRICO 
LEIA angulo 
SE angulo > 360 OU angulo < -360 
ENTÃO INÍCIO 
voltas + parte inteira(angulo / 360) 
angulo —  RESTO(angulo / 360) 
FIM 
SENÃO voltas — 0 
SE angulo = 0 OU angulo = 90 OU angulo = 180 
OU angulo = 270 OU angulo = 360 
OU angulo = -90 OU angulo = -180 
OU angulo = -270 OU angulo = -360 
ENTÃO ESCREVA “Está em cima de algum dos eixos” 
SE (angulo > 0 E angulo < 90) OU (angulo < -270 E angulo > -360) 
ENTÃO ESCREVA “1º Quadrante” 
SE (angulo > 90 E angulo < 180) OU (angulo < -180 E angulo > -270) 
ENTÃO ESCREVA “2º Quadrante” 
SE (angulo > 180 E angulo < 270) OU (angulo < -90 E angulo > -180) 
ENTÃO ESCREVA “3º Quadrante” 
SE (angulo > 270 E angulo < 360) OU (angulo < 0 E angulo > -90) 
ENTÃO ESCREVA “4º Quadrante” 
ESCREVA voltas, “ volta(s) no sentido “ 
SE angulo < 0 
ENTÃO ESCREVA “horário” 
SENÃO ESCREVA “anti-horário” 
FIM ALGORITMO. 


INe NM SOLUÇÃO: 
C 


\EXERC\CAP4\PASCAL\EX25.PAS e \EXERC\CAP4\PASCAL\EX25.EXE 


ePAeR Ra SoLuçÃo: 
GEES 
\EXERC\CAP4\C++\EX25.CPP e \EXERC\CAP4\C++\EX25. EXE 
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RANMA SoLução: 
Gisa 


\EXERC\CAP4\JAVA\EX25.java e NEXERCICAP4JAVANEX25.class 


EXERCÍCIOS PROPOSTOS 


EEB Faça um programa que receba quatro notas de um aluno, calcule e mostre a média aritmética das notas e a 
mensagem de aprovado ou reprovado, considerando para aprovação média 7. 


IFA Faça um programa que receba duas notas, calcule e mostre a média aritmética e a mensagem que se encontra 
na tabela a seguir: 


MÉDIA ARITMÉTICA MENSAGEM 
0,0 e—o 30 Reprovado 
3,0 ee—o 7,0 Exame 
7,0 e— e. 100 Aprovado 


IEA Faça um programa que receba dois números e mostre o menor. 
EA Faça um programa que receba três números e mostre o maior. 


REA Faça um programa que receba dois números e execute as operações listadas a seguir, de acordo com a escolha 
do usuário. 


ESCOLHA DO USUÁRIO OPERAÇÃO 
Média entre os números digitados 
Diferença do maior pelo menor 
Produto entre os números digitados 
Divisão do primeiro pelo segundo 


BWIN 


Se a opção digitada for inválida, mostre uma mensagem de erro e termine a execução do programa. 
Lembre-se de que, na operação 4, o segundo número deve ser diferente de zero. 

EE Faça um programa que receba dois números e execute uma das operações listadas a seguir, de acordo com a 
escolha do usuário. Se for digitada uma opção inválida, mostre mensagem de erro e termine a execução do 
programa. Às opções são: 

a) O primeiro número elevado ao segundo número. 
b) Raiz quadrada de cada um dos números. 
c) Raiz cúbica de cada um dos números. 
IEA Uma empresa decide dar um aumento de 30% aos funcionários com salários inferiores a R$ 500,00. Faça um 


programa que receba o salário do funcionário e mostre o valor do salário reajustado ou uma mensagem, caso 
ele não tenha direito ao aumento. 


REA Faça um programa para calcular e mostrar o salário reajustado de um funcionário. O percentual de aumento 
encontra-se na tabela a seguir. 


SALÁRIO PERCENTUAL DE AUMENTO 
Até R$ 300,00 35% 
Acima de R$ 300,00 15% 


BEER Um banco concederá um crédito especial aos seus clientes, de acordo com o saldo médio no último ano. Faça 
um programa que receba o saldo médio de um cliente e calcule o valor do crédito, de acordo com a tabela a 
seguir. Mostre o saldo médio e o valor do crédito. 
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SALDO MÉDIO PERCENTUAL 
Acima de R$ 400,00 30% do saldo médio 
R$ 400,00 eo R$300,00 25% do saldo médio 
R$300,00 eo R$200,00 20% do saldo médio 
Até R$ 200,00 10% do saldo médio 


ELJ O preço ao consumidor de um carro novo é a soma do custo de fábrica com a porcentagem do distri- 
buidor e dos impostos, ambos aplicados ao custo de fábrica. As porcentagens encontram-se na tabela a 
seguir. Faça um programa que receba o custo de fábrica de um carro e mostre o preço ao consumidor. 


CUSTO DE FÁBRICA % DO DISTRIBUIDOR % dos IMPOSTOS 
Até R$ 12.000,00 5 isento 
Entre R$ 12.000,00 e R$ 25.000,00 10 15 
Acima de R$ 25.000,00 15 20 


EEB Faça um programa que receba o salário atual de um funcionário e, usando a tabela a seguir, calcule e 
mostre o valor do aumento e o novo salário. 


SALÁRIO PERCENTUAL DE AUMENTO 
Até R$ 300,00 15% 
R$ 300,00 o—o R$ 600,00 10% 
R$ 600,00 es R$900,00 5% 
Acima de R$ 900,00 0% 


EPA Faça um programa que receba o salário bruto de um funcionário e, usando a tabela a seguir, calcule e 
mostre o valor a receber. Sabe-se que este é composto pelo salário bruto acrescido de gratificação e des- 
contado o imposto de 7% sobre o salário. 


TABELA DAS GRATIFICAÇÕES 
SALÁRIO GRATIFICAÇÃO 
Até R$ 350,00 R$ 100,00 
R$350,00 O—o R$600,00 R$ 75,00 
R$ 600,00 ee R$900,00 R$ 50,00 
Acima de R$ 900,00 R$ 35,00 


EEJ Faça um programa que receba o preço de um produto, calcule e mostre, de acordo com as tabelas a se- 
guir, o novo preço e a classificação. 


TABELA 1 — PERCENTUAL DE AUMENTO 


PREÇO % 
Até R$ 50,00 5 
Entre R$ 50,00 e R$ 100,00 10 
Acima de R$ 100,00 15 


TABELA 2 — CLASSIFICAÇÕES 


NOVO PREÇO CLASSIFICAÇÃO 
Até R$ 80,00 Barato 
Entre R$ 80,00 e R$ 120,00 (inclusive) Normal 
Entre R$ 120,00 e R$ 200,00 (inclusive) Caro 


Maior que R$ 200,00 Muito caro 
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ELA Faça um programa que receba o salário de um funcionário e, usando a tabela a seguir, calcule e mostre 
o novo salário. 


FAIXA SALARIAL % DE AUMENTO 
Até R$ 300,00 50% 
R$ 300,00 Os R$500,00 40% 
R$500,00 oe R$700,00 30% 
R$700,00 Os R$800,00 20% 
R$800,00 0O——e R$ 1.000,00 10% 
Acima de R$ 1.000,00 5% 


Uma agência bancária possui dois tipos de investimentos, conforme o quadro a seguir. Faça um pro- 
3 
grama que receba o tipo de investimento e seu valor, calcule e mostre o valor corrigido após um mês de 
investimento, de acordo com o tipo de investimento. 


TIPO DESCRIÇÃO RENDIMENTO MENSAL 
1 Poupança 3% 
2 Fundos de renda fixa 4% 


HA Uma empresa decide aplicar descontos nos seus preços usando a tabela a seguir. Faça um programa que 
receba o preço atual de um produto e seu código, calcule e mostre o valor do desconto e o novo preço. 


PREÇO ATUAL % DE DESCONTO 
Até R$ 30,00 Sem desconto 
Entre R$ 30,00 e R$ 100,00 10% 
Acima de R$ 100,00 15% 


ERA Faça um programa que verifique a validade de uma senha fornecida pelo usuário. A senha é 4531. O 
programa deve mostrar uma mensagem de permissão de acesso ou não. 


EEA Faça um programa que receba a idade de uma pessoa e mostre a mensagem de maioridade ou não. 


E ER Faça um programa que receba a altura e o sexo de uma pessoa e calcule e mostre seu peso ideal, utilizan- 
do as seguintes fórmulas (onde h é a altura): 


para homens: (72.7 - h) — 58. 
para mulheres: (62.1 » h) — 44.7. 


ER Faça um programa que receba a idade de um nadador e mostre sua categoria, usando as regras a seguir. 
Para idade inferior a 5, deverá mostrar mensagem. 


CATEGORIA IDADE 
Infantil 5a7 
Juvenil 8a lo 
Adolescente 11a15 
Adulto 16a30 
Sênior Acima de 30 


PIE Faça um programa que receba o preço de um produto e seu código de origem e mostre sua procedência. 
A procedência obedece à tabela a seguir. 
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CÓDIGO DE ORIGEM PROCEDÊNCIA 


1 Sul 

2 Norte 

5 Leste 

4 Oeste 
5ou6 Nordeste 

7ou80u9 Sudeste 

10 a 20 Centro-oeste 
21a 30 Nordeste 


EYA Faça um programa que receba a idade e o peso de uma pessoa. De acordo com a tabela a seguir, verifique 
e mostre em qual grupo de risco essa pessoa se encaixa. 


PESO 
IDADE z : = 
Até 60 Entre 60 e 90 (inclusive) Acima de 90 
Menores que 20 9 8 7 
De 20 a 50 6 5 4 
Maiores que 50 3 2 1 


PER Faça um programa que receba: 
o código do produto comprado; e 
a quantidade comprada do produto. 
Calcule e mostre: 
o preço unitário do produto comprado, seguindo a Tabela I; 
o preço total da nota; 
o valor do desconto, seguindo a Tabela II e aplicado sobre o preço total da nota; e 
o preço final da nota depois do desconto. 


TABELA | TABELA II 
CÓDIGO PREÇO PREÇO TOTAL DA NOTA % DE DESCONTO 
Tao R$ 10,00 Até R$ 250,00 5% 
11a20 R$ 15,00 Entre R$ 250,00 e R$ 500,00 10% 
21a 30 R$ 20,00 Acima de R$ 500,00 15% 
31a40 R$ 30,00 


EZH Faça um programa que receba o preço, a categoria (1 — limpeza; 2 — alimentação; ou 3 — vestuário) 
e a situação (R — produtos que necessitam de refrigeração; e N — produtos que não necessitam de re- 
frigeração). 

Calcule e mostre: 


O valor do aumento, usando as regras que se seguem. 


PREÇO CATEGORIA PERCENTUAL DE AUMENTO 
1 5% 
<=25 2 8% 
3 10% 
1 12% 
>25 2 15% 
3 18% 


O valor do imposto, usando as regras a seguir. 
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O produto que preencher pelo menos um dos seguintes requisitos pagará imposto equivalente a 5% 


do preço; caso contrário, pagará 8%. Os requisitos são: 


Categoria: 2 
Situação: R 


O novo preço, ou seja, o preço mais aumento menos imposto. 


A classificação, usando as regras a seguir. 


NOVO PREÇO 
<= R$ 50,00 
Entre R$ 50,00 e R$ 120,00 
>= R$ 120,00 


CLASSIFICAÇÃO 
Barato 

Normal 

Caro 


FEM Uma empresa decidiu dar uma gratificação de Natal a seus funcionários, baseada no número de horas 
extras e no número de horas que o funcionário faltou ao trabalho. O valor do prêmio é obtido pela con- 


sulta à tabela que se segue, na qual: 


H = número de horas extras — (2/3 * (número de horas falta)) 


H (MINUTOS) 
>= 2.400 
1.800 O—o 2.400 
1200 e—o 1.800 
600 e—o 1.200 
< 600 


PRÊMIO (R$) 
500,00 
400,00 
300,00 
200,00 
100,00 


CAPÍTULO 


Estrutura 


de repetição 


5.1 Estrutura de repetição em algoritmo 


Uma estrutura de repetição é utilizada quando um trecho do algoritmo, ou até mesmo o algoritmo in- 
teiro, precisa ser repetido. O número de repetições pode ser fixo ou estar atrelado a uma condição. Assim, 
existem estruturas para tais situações, descritas a seguir. 


5.11 Estrutura de repetição para número definido de repetições (estrutura PARA) 


Essa estrutura de repetição é utilizada quando se sabe o número de vezes que um trecho do algoritmo 
deve ser repetido. O formato geral dessa estrutura é: 


PARA I + valor inicial ATÉ valor final FAÇA [PASSO n] 
INÍCIO 

comandol 

comando? 


comandom 
FIM 
O comando1, o comando2 € o comandom serão executados utilizando-se a variável 1 como controle, e 

seu conteúdo vai variar do valor inicialatéo valor final. A informação do Passo está entre colchetes 
porque é opcional. O Passo indica como será a variação da variável de controle. Por exemplo, quando for 
indicado PAsso 2, a variável de controle será aumentada em 2 unidades a cada iteração até atingir o va- 
lor final. Quando a informação do Passo for suprimida, isso significa que o incremento ou o decremento 
da variável de controle será de 1 unidade. 


Quando houver apenas um comando a ser repetido, os marcadores de bloco INÍCIO e FIM poderão ser 
suprimidos. 


Exemplos: 
PARA I — 1 ATÉ 10 FAÇA 
ESCREVA I 
O comando ESCREVA I será executado dez vezes, ou seja, para I variando de 1 a 10. Assim, os valores 
de I serão: 1, 2, 3, 4, 5,6,7, 8,9 e 10. 
PARA J — 1 ATÉ 9 FAÇA PASSO 2 
ESCREVA J 
O comando ESCREVA J será executado cinco vezes, ou seja, para J variando de 1 a 9, de 2 em 2. Assim, 


os valores de J serão: 1, 3, 5,7 e 9. 


PARA I — 10 ATÉ 5 FAÇA PASSO -1 
ESCREVA I 


96 | Fundamentos da programação de computadores 


O comando ESCREVA I será executado seis vezes, ou seja, para I variando de 10 a 5. Assim, os valores 
de serão: 10,9,8,7,6€e5. 


PARA J — 15 ATÉ 1 FAÇA PASSO -2 
ESCREVA J 


O comando ESCREVA J será executado oito vezes, ou seja, para J variando de 15 a 1, de 2 em 2. Assim, 
os valores de J serão: 15, 13, 11,9,7,5,3€e1. 

Existem duas instruções comumente usadas nos comandos internos das estruturas de repetição. São as 
instruções denominadas acumuladores e contadores. 

Os acumuladores devem ser usados quando a realização de um cálculo precisa de valores obtidos a 
cada iteração, ou seja, o cálculo só estará pronto com a conclusão da repetição. É por isso que um acu- 
mulador deve ser inicializado com um valor neutro para a operação em que será utilizado. Por exemplo, 
se for usado em uma adição, deve ser inicializado com zero; se for usado em uma multiplicação, deve ser 
inicializado com 1. 


Exemplo de acumulador: 


SOMA — 0 // inicialização da variável SOMA com o valor zero 

PARA I < 1 ATÉ 5 FAÇA 

INÍCIO 

ESCREVA “Digite um número: ” 

LEIA NUM 

SOMA <— SOMA + NUM // acumulando o valor da variável NUM na variável soma 
FIM 


ESCREVA “Soma = “, SOMA 


Simulação: 
MEMÓRIA TELA 
| NUM SOMA 
0 Inicialização da variável SOMA com o valor zero 
SOMA — O 
1 Digite um número: 5 
1 5 
i E 7 Acumulando o valor da variável NUM na variável SOMA 
SOMA — SOMA + NUM 
Digite um número: 3 
2 5 
> 3 8 Acumulando o valor da variável NUM na variável SOMA 
SOMA — SOMA + NUM 
Digite um número: O 
0 
3 0 8 Acumulando o valor da variável NUM na variável SOMA 
SOMA — SOMA + NUM 
4 Digite um número: 10 
4 10 
f 10 18 Acumulando o valor da variável NUM na variável SOMA 
SOMA — SOMA + NUM 
Digite um número: 2 
2 
E > 50 Acumulando o valor da variável NUM na variável SOMA 
SOMA — SOMA + NUM 


Soma = 20 
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Exemplo de contador: 


CONT — 0 // inicialização da variável CONT com o valor zero 
PARA I — 1 ATÉ 5 FAÇA 

INÍCIO 

ESCREVA “Digite um número: ” 

LEIA NUM 


SE (NUM > 5) 
ENTÃO CONT < CONT + 1 // contando mais 1 na variável CONT 
FIM 
ESCREVA “Quantidade de número maiores que 5 = “,CONT 


Simulação: 
MEMÓRIA TELA 
| NUM CONT 
Inicialização da variável CONT com o valor 
(0) zero 
CONT — O 
1 Digite um número: 5 
1 5 
| 5 0 O número digitado não é maior que 5, 
logo, o contador CONT não será alterado 
Digite um número: 12 
2 
O número digitado é maior que 5, logo, 
o contador CONT será incrementado em 
2 12 1 f 
1 unidade 
CONT — CONT + 1 
Digite um número: 8 
8 
O número digitado é maior que 5, logo, 
o contador CONT será incrementado em 
3 8 2 ; 
1 unidade 
CONT — CONT + 1 
4 Digite um número: 3 
4 5 
4 3 > O número digitado não é maior que 5, 
logo, o contador CONT não será alterado 
Digite um número: 6 
6 
O número digitado é maior que 5, logo, 
5 6 3 o contador CONT será incrementado em 


1 unidade 
CONT — CONT + 1 


Quantidade de números maiores que 5 = 3 


5.1.2 Estrutura de repetição para número indefinido de repetições e teste no início (estrutura 
ENQUANTO) 


Essa estrutura de repetição é utilizada quando não se sabe o número de vezes que um trecho do algorit- 
mo deve ser repetido, embora também possa ser utilizada quando se conhece esse número. 

Essa estrutura baseia-se na análise de uma condição. A repetição será feita enquanto a condição se 
mostrar verdadeira. 


98 | Fundamentos da programação de computadores 


Existem situações em que o teste condicional da estrutura de repetição, que fica no início, resulta em 
um valor falso logo na primeira comparação. Nesses casos, os comandos escritos dentro da estrutura de 
repetição não serão executados. 


ENQUANTO condição FAÇA 
comandol 


Enquanto a condição for verdadeira, o comando1 será executado. 


ENQUANTO condição FAÇA 
INÍCIO 

comandol 

comando2 

comando3 
FIM 


Enquanto a condição for verdadeira, o comando1l, O comando? € o comando3 serão executados. 


Exemplos: 
Xe // inicialização da variável X com o valor 1 
ye- 5 // inicialização da variável Y com o valor 5 
ENQUANTO X < Y FAÇA 
INÍCIO 
Xe x+2 // contador incrementado em 2 unidades 
Ye y+1 // contador incrementado em 1 unidade 
FIM 
Simulação: 
X Y 
1 5 Valores iniciais 
3 6 
5 7 , . 
p E Valores obtidos dentro da estrutura de repetição 
9 9 


No trecho do algoritmo anterior, portanto, os comandos que estão dentro da estrutura de repetição são 
repetidos quatro vezes. 


x — 1 // inicialização da variável X com o valor 1 
Y — 1 // inicialização da variável Y com o valor 1 
ENQUANTO X <= 5 FAÇA 

INÍCIO 

Y < Y +*+ x // acumulador das multiplicações 

xe X + 1 // contador incrementado em 1 unidade 
FIM 


Simulação: 


1 1 Valores iniciais 


Valores obtidos dentro da estrutura de repetição 


SD UM EB WIN 


120 


Capítulo 5 Estrutura de repetição | 99 


No trecho do algoritmo anterior, portanto, os comandos que se localizam na estrutura de repetição são 
repetidos cinco vezes. Nesse exemplo, a estrutura ENQUANTO é utilizada para repetir o trecho do algoritmo 
em um número definido de vezes. 


5.1.3 Estrutura de repetição para número indefinido de repetições e teste no final (estrutura REPITA) 


Essa estrutura de repetição é utilizada quando não se sabe o número de vezes que um trecho do algorit- 
mo deve ser repetido, embora também possa ser utilizada quando se conhece esse número. 

Essa estrutura baseia-se na análise de uma condição. A repetição será feita até a condição se tornar 
verdadeira. 

A diferença entre a estrutura ENQUANTO e a estrutura REPITA é que, nessa última, os comandos serão 
repetidos pelo menos uma vez, já que a condição de parada se encontra no final. 


REPITA 
comandos 
ATÉ condição 


Repita os comandos até a condição se tornar verdadeira. 


Exemplos: 

ue il // inicialização da variável X com o valor 1 
ye- 5 // inicialização da variável Y com o valor 5 
REPITA 

xe x+2 // contador incrementado em 2 unidades 
Ye v+1 // contador incrementado em 1 unidade 


ATÉ X >= Y 


Simulação: 


x< 


Valores iniciais 


Valores obtidos dentro da estrutura de repetição 


OIN A| Wo a 
o o NO UU =< 


No trecho do algoritmo anterior, portanto, os comandos escritos dentro da estrutura de repetição são 
repetidos quatro vezes. 


ue il // inicialização da variável X com o valor 1 
v i // inicialização da variável Y com o valor 1 
REPITA 
Ye Y*x // acumulador das multiplicações 
E // contador incrementado em 1 unidade 
ATÉ X = 6 
Simulação: 

Y X 

1 1 Valores iniciais 

1 2 

2 3 , . 

6 A Valores obtidos dentro da estrutura de repetição 

24 5 

6 
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No trecho do algoritmo anterior, portanto, os comandos que se localizam dentro da estrutura de re- 
petição são repetidos cinco vezes. Nesse exemplo, a estrutura REPITA é utilizada para repetir o trecho do 
algoritmo em um número definido de vezes. 


5.2 Estrutura de repetição em PASCAL 
5.2.1 Estrutura de repetição FOR 


Essa estrutura de repetição é utilizada quando se sabe o número de vezes que um trecho do programa 
deve ser repetido. 


FOR I := valor inicial TO valor final DO 
comando; 


O comando será executado utilizando-se a variável 1 como controle, e seu conteúdo vai variar do va- 
lor_inicial até o valor_final, de 1 em 1, incrementando automaticamente. 


FOR J := valor_inicial TO valor_final DO 
BEGIN 
comandol ; 


comando? ; 
END; 


O comandol € O comando? serão executados utilizando-se a variável 3 como controle, e seu conteúdo vai 
variar do valor inicial até o valor final, de 1 em 1, incrementando automaticamente. 


FOR K := valor inicial DOWNTO valor final DO 
comando; 


O comando será executado utilizando-se a variável K como controle, e seu conteúdo vai variar do va- 
lor inicial até o valor final, de 1 em 1, decrementando automaticamente. 


FOR H := valor inicial DOWNTO valor final DO 
BEGIN 

comandol ; 

comando? ; 

comando3; 
END; 


O comando1, o comando? € O comando3 serão executados utilizando-se a variável E como controle, e seu 
conteúdo vai variar do valor inicial até o valor final, de 1 em 1, decrementando automaticamente. 


GO Observações 


Na linguagem PASCAL, a estrutura de repetição FOR funciona obrigatoriamente de 1 em 1, incre- 
mentando ou decrementando. 


Exemplos: 
FOR i := 1 TO 5 DO 
WRITELN(i); 


No trecho de programa anterior, o comando WRITELN( i); será executado cinco vezes, ou seja, para 
i valendo 1,2,3,4€e5. 


FOR i := 10 DOWNTO 1 DO 
WRITELN(i); 


No trecho de programa anterior, o comando wRITELN(i); será executado dez vezes, ou seja, para 
i valendo 10, 9, 8, 7,6,5,4,3,2€e1. 
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Existem duas instruções comumente usadas nos comandos internos das estruturas de repetição. São as 
instruções denominadas acumuladores e contadores. 

Os acumuladores devem ser usados quando a realização de um cálculo precisa de valores obtidos a cada 
iteração, ou seja, o cálculo só estará pronto com a conclusão da repetição. É por isso que um acumulador deve 
ser inicializado com um valor neutro para a operação em que será utilizado. Por exemplo, se for usado em 
uma adição, deve ser inicializado com zero, e se for usado em uma multiplicação, deve ser inicializado com 1. 


Exemplo de acumulador: 


// inicialização da variável SOMA com o valor zero 


WRITE('Digite um número: '); 

READLN (NUM) ; 

SOMA := SOMA + NUM; // acumulando o valor da variável NUM na variável SOMA 
END; 
WRITELN('Soma = *,SOMA); 


Simulação: 
MEMÓRIA TELA 
| NUM SOMA 
0 Inicialização da variável SOMA com o valor zero 

SOMA := 0; 
1 Digite um número: 5 
1 5 
i E E Acumulando o valor da variável NUM na variável SOMA 

SOMA := SOMA + NUM; 
2 Digite um número: 3 
2 3 
> 3 8 Acumulando o valor da variável NUM na variável SOMA 

SOMA := SOMA + NUM; 
3 Digite um número: O 
3 0 
3 0 8 Acumulando o valor da variável NUM na variável SOMA 

SOMA := SOMA + NUM; 
4 Digite um número: 10 
4 10 
4 10 18 Acumulando o valor da variável NUM na variável SOMA 

SOMA := SOMA + NUM; 
5 Digite um número: 2 
5 2 
5 > 20 Acumulando o valor da variável NUM na variável SOMA 


SOMA := SOMA + NUM; 
Soma = 20 


Exemplo de contador: 


CONT := 0; // inicialização da variável CONT com o valor zero 
FOR I := 1 TO 5 DO 
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WRITE ('Digite um número: '); 

READLN (NUM) ; 

IF (NUM > 5) 

THEN CONT := CONT + 1; // contando mais 1 na variável CONT 
END; 
WRITELN( 'Quantidade de número maiores que 5 = ',CONT); 


Simulação: 
MEMÓRIA TELA 
| NUM CONT 
0 Inicialização da variável CONT com o valor zero 

CONT := 0; 
1 Digite um número: 5 
1 9 
| 5 0 O número digitado não é maior que 5, logo, o 

contador CONT não será alterado 
2 Digite um número: 12 
2 12 

O número digitado é maior que 5, logo, o 
2 12 1 contador CONT será incrementado em 1 unidade 

CONT := CONT + 1; 
3 Digite um número: 8 
5 8 

O número digitado é maior que 5, logo, o 
5 8 2 contador CONT será incrementado em 1 unidade 

CONT := CONT + 1; 
4 Digite um número: 3 
4 5 
4 z > O número digitado não é maior que 5, logo, o 

contador CONT não será alterado 
5 Digite um número: 6 
5 6 

O número digitado é maior que 5, logo, o 
5 6 3 contador CONT será incrementado em 1 unidade 


CONT := CONT + 1; 
Quantidade de números maiores que 5 = 3 


5.2.2 Estrutura de repetição WHILE 


A estrutura de repetição WHILE é utilizada quando o número de repetições necessárias não for fixo, 
apesar de também ser utilizada quando se conhece a quantidade de repetições. 

Nessa estrutura os comandos serão repetidos enquanto a condição for verdadeira e o teste condicional 
ocorre no início. Isso significa que existe a possibilidade da repetição não ser executada quando a condição 
assumir o valor falso logo na primeira verificação. 


WHILE condição DO 
comando; 


Enquanto a condição for verdadeira, o comando será executado. 


WHILE condição DO 
BEGIN 
comandol ; 
comando? ; 
END; 


Enquanto a condição for verdadeira, o comandol e o comando? serão executados. 
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X := 0; // inicialização da variável X com o valor zero 
WHILE X <> 5 DO 

BEGIN 

WRITELN('Valor de X = ',X); 

X :=X+ 1l; // contador incrementado em 1 unidade 

END; 

WRITELN('Valor de X depois que sair da estrutura = ',X); 


No trecho de programa anterior, os comandos WRITELN('Valor de X = ’ʻ,X)exXx := X + 1; foram 
executados cinco vezes. O teste condicional avalia x valendo 0, 1, 2, 3, 4e 5. 
Simulação: 
TELA X 
0 Valor inicial 
Valor deX= 0 1 
Valor de X= 1 2 f f 
Valores obtidos dentro da estrutura de repetição 
Valor de X= 2 3 
Valor de X=3 4 
Valor de X= 4 5 Valor obtido dentro da estrutura de repetição, que 
torna a condição falsa e interrompe a repetição 
Valor de X depois que 
sair da estrutura = 5 
x g= ilg // inicialização da variável X com o valor 1 
Y := 10; // inicialização da variável Y com o valor 10 
WHILE Y > X DO 
BEGIN 
WRITELN('Valor de Y = ',Y); 
Y := Y — 2; // contador decrementado em 2 unidades 
END; 


WRITELN('Valor de Y depois que sair da estrutura = ',Y); 


No trecho de programa anterior, os comandos WRITELN('Valor de Y = “,y);ey := Y — 2; foram 
executados cinco vezes. O teste condicional avalia y valendo 10, 8, 6,4,2 e0. 
Simulação: 
TELA X Y 
1 10 Valores iniciais 
Valor de Y = 10 1 8 
Valor de Y = 8 1 6 : ; 
Valores obtidos dentro da estrutura de repetição 
Valor de Y = 6 1 4 
Valor de Y = 4 1 2 
Misao i 0 Valor obtido dentro da estrutura de repetição, que 
torna a condição falsa e interrompe a repetição 
Valor de Y depois que 
sair da estrutura = O 
x g= ile // inicialização da variável x com o valor 1 
w g= ilp // inicialização da variável y com o valor 1 
WHILE X < Y DO 
BEGIN 


WRITELN('Valor de X = ',X); 
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X :=X+ 1l; // contador incrementado em 1 unidade 
END; 
No trecho de programa anterior, os comandos WRITELN ('Valor de X = ',X);€X := X + 1; não são 


executados, pois com os valores iniciais de x e y a condição é falsa, logo, não ocorre a entrada na estrutura 
de repetição para execução de seus comandos. 


5.2.3 Estrutura de repetição REPEAT 


A estrutura de repetição REPEAT é utilizada quando o número de repetições necessárias não for fixo, 
apesar de também ser utilizada quando se conhece o número de repetições. 

Nessa estrutura, os comandos serão repetidos até a condição se tornar verdadeira, e o teste condicional 
ocorre no final, o que significa que os comandos internos da estrutura da repetição serão executados, no 
mínimo, uma vez. 


REPEAT 


comandos ; 
UNTIL condição; 


Os comandos serão repetidos até que a condição se torne verdadeira. 


Exemplos: 
X := 0; // inicialização da variável X com o valor 0 
REPEAT 
WRITELN('Valor de X = ',X); 
X :=X+ 1l; // contador incrementado em 1 unidade 
UNTIL X = 5; 
WRITELN('Valor de X depois que sair da estrutura = ',X); 
No trecho de programa anterior, os comandos WRITELN('Valor de X = !,X);exX := X + 1; foram 
executados cinco vezes. O teste condicional avalia x valendo 1, 2, 3, 4e 5. 
Simulação: 
TELA X 
0 Valor inicial 
Valor de X = 0 1 
Valor de X= 1 2 . ; 
Valores obtidos dentro da estrutura de repetição 
Valor de X= 2 3 
Valor de X= 3 4 
ordeka 5 Valor obtido dentro da estrutura de repetição, que 


torna a condição verdadeira e interrompe a repetição 


Valor de X depois que 
sair da estrutura = 5 


No trecho do algoritmo anterior, portanto, os comandos que se localizam na estrutura de repetição são 
repetidos cinco vezes. Nesse exemplo, a estrutura REPITA é utilizada para repetir o trecho do algoritmo em 
um número definido de vezes. 


s ge ia // inicialização da variável X com o valor 1 
Y := 10; // inicialização da variável Y com o valor 10 
REPEAT 
WRITELN('Valor de Y = ʻ,Y); 
Y := Y — 2; // contador decrementado em 2 unidades 
UNTIL Y <= X; 
WRITELN('Valor de Y depois que sair da estrutura = ʻ',Y); 
No trecho de programa anterior, os comandos WRITELN('Valor de Y = !,Y);€Y := Y — 2; serão 


executados cinco vezes. O teste condicional avaliará y valendo 8, 6, 4,2 e 0. 
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Simulação: 
TELA X Y 
1 10 Valores iniciais 

Valor de Y = 10 1 8 

Valor de Y = 8 1 6 . l 
Valores obtidos dentro da estrutura de repetição 

Valor de Y = 6 1 4 

Valor de Y = 4 1 2 

rev 1 0 Valor obtido dentro da estrutura de repetição, que 
torna a condição verdadeira e interrompe a repetição 

Valor de Y depois que 


sair da estrutura = O 


5.3 Estrutura de repetição em C/C++ 


5.3.1 Estrutura de repetição FOR 


Essa estrutura de repetição é utilizada quando se sabe o número de vezes que um trecho do programa 


deve ser repetido. 
O formato geral do comando for é composto por três partes: 


for (i = valor inicial; condição; incremento ou decremento de i) 
comando; 


A primeira parte atribui um valor inicial à variável i, que tem como função controlar o número 
necessário de repetições. 

A segunda parte corresponde a uma expressão relacional que, quando assumir o valor falso, determi- 
nará o fim da repetição. 

A terceira parte é responsável por alterar o valor da variável i (incremento ou decremento) com o ob- 
jetivo de, em algum momento, fazer a condição assumir o valor falso. 

Caso seja necessária a repetição de apenas um comando, o compilador entenderá que a estrutura de 
repetição terminará quando for encontrado o primeiro ; (ponto e vírgula). 


Exemplo: 


for (a = 1;a <= 20;a++) 
printf(“ino valor de a é: 2d" ,a); 


No exemplo anterior, à variável a é atribuído inicialmente o valor 1 (a = 1) que, depois, é incrementado em 
uma unidade (a++). 

À cada incremento, o comando printf será executado. Esse processo se repete até o valor da variável a se 
tornar maior que 20 (quando a condição a <= 20 assumir o valor falso). 

Se for necessária a repetição de mais de um comando, o compilador entenderá que a estrutura de repetição 
começará quando for encontrado o símbolo ( e terminará quando for encontrado o símbolo ). 


Exemplo: 


for (a = 15;a >= 1;a = a-2) 
{ 
printf(“Digite um número: “); 
scanf ("3d3%*C”,&x); 


; 


No exemplo anterior, a variável a é inicializada com o valor 15 (a = 15) que, depois, é decrementada 
em duas unidades (a = a -2). 

A cada decremento, o bloco de comando que está entre chaves (... } é executado. Esse processo se repete 
até o valor da variável a se tornar menor que 1 (quando a condição a >= 1 assumir o valor falso). 
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Exemplos: 


ope (tl = do dt <= 50 dA) 
printf(“Sd",i); 

ou 

for (Ut = lo atos So ad Ss sai) 
printf(“Sd",i); 


Nos trechos de programa anteriores, que, apesar de utilizarem formas diferentes para aumentar o valor 
da variável i, expressam a mesma coisa, o comando printf (“sd”,i); foi executado cinco vezes, ou seja, 
para i valendo 1,2,3,4€e5. 

for (i = 10; i >= 1; i--) 
printf(“Sd”",i); 

ou 

ore (at = 0 ad DS do do = oi) 
printf(“Sd",i); 


Nos trechos de programa anterior, que, apesar de utilizarem formas diferentes para diminuir o valor da 
variável i, são exatamente a mesma coisa, o comando printf(“sd”,i); será executado dez vezes, ou seja, 
para i valendo 10, 9, 8, 7,6,5,4,3,2€e1. 


FOr A ESO T ESSO E TEZ) 
printf(“%d"”,i); 


No trecho de programa anterior, o comando printf (”%d",i); será executado seis vezes, ou seja, para 
i valendo 0, 2, 4, 6, 8 e 10. 


for (i = 100; i >= 0; ài = i-20) 
printf(“2d",i); 


No trecho de programa anterior, o comando printf (“sd",i); será executado seis vezes, ou seja, para 
i valendo 100, 80, 60, 40, 20 e 0. 

Existem duas instruções comumente usadas nos comandos internos das estruturas de repetição. São as 
instruções denominadas acumuladores e contadores. 

Os acumuladores devem ser usados quando a realização de um cálculo precisa de valores obtidos a 
cada iteração, ou seja, o cálculo só estará pronto com a conclusão da repetição. É por isso que um acu- 
mulador deve ser inicializado com um valor neutro para a operação em que será utilizado. Por exemplo, 
se for usado em uma adição, deve ser inicializado com zero; se for usado em uma multiplicação, deve ser 
inicializado com 1. 


Exemplo de acumulador: 


SOMA = 0; // inicialização da variável SOMA com o valor zero 
for(I = 1; 1 <= 5; I++) 

{ 

printf(“Digite um número: “); 


scanf (“2$d%*c”, &NUM) ; 
SOMA = SOMA + NUM; // acumulando o valor da variável NUM na variável SOMA 


} 
printf(“Soma = %d”,SOMA); 


Capítulo 5 Estrutura de repetição | 107 


Simulação: 
MEMÓRIA TELA 
| NUM SOMA 
0 Inicialização da variável SOMA com o valor zero 

SOMA = 0; 
1 Digite um número: 5 
1 5 
i 5 5 Acumulando o valor da variável NUM na variável SOMA 

SOMA = SOMA + NUM; 
2 Digite um número: 3 
2 3 
> 3 8 Acumulando o valor da variável NUM na variável SOMA 

SOMA = SOMA + NUM; 
3 Digite um número: O 
3 0 
3 0 8 Acumulando o valor da variável NUM na variável SOMA 

SOMA = SOMA + NUM; 
4 Digite um número: 10 
4 10 
4 10 18 Acumulando o valor da variável NUM na variável SOMA 

SOMA = SOMA + NUM; 
5 Digite um número: 2 
5 2 
E > 20 Acumulando o valor da variável NUM na variável SOMA 


SOMA = SOMA + NUM; 
Soma = 20 


Exemplo de contador: 


CONT = 0; // inicialização da variável CONT com o valor zero 
for(I = 1; I<= 5; I++) 
{ 


printf(“Digite um número: “); 
scanf (“2$d%*c”, &NUM) ; 
if (NUM > 5) 
CONT = CONT + 1; // contando mais 1 na variável CONT 
} 


printf (“Quantidade de número maiores que 5 = %d”,CONT); 


Simulação: 
MEMÓRIA TELA 

| NUM CONT 

0 Inicialização da variável CONT com o valor zero 

CONT=0; 

1 Digite um número: 5 
1 5 
| 5 0 O número digitado não é maior que 5, logo, o 


contador CONT não será alterado 
Digite um número: 12 
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MEMÓRIA TELA 
| NUM CONT 
O número digitado é maior que 5, logo, o 
contador CONT será incrementado em 1 
2 12 1 ç 
unidade 
CONT = CONT + 1; 
Digite um número: 8 
8 
O número digitado é maior que 5, logo, o 
contador CONT será incrementado em 1 
5 8 2 : 
unidade 
CONT = CONT + 1; 
4 Digite um número: 3 
4 3 
4 3 > O número digitado não é maior que 5, logo, o 
contador CONT não será alterado 
Digite um número: 6 
6 
O número digitado é maior que 5, logo, o 
contador CONT será incrementado em 1 
5 6 5 i 
unidade 
CONT = CONT + 1; 


Quantidade de números maiores que 5 = 3 


À terceira parte da estrutura de repetição FoR é um contador que pode ser incrementado ou decrementado. 


Exemplos: 

II+; // contador incrementado em 1 unidade 

I++; // contador incrementado em 1 unidade 

Ie ii; // contador decrementado em 1 unidade 

I-s; // contador decrementado em 1 unidade 

1I=1+2; // contador incrementado em 2 unidades 
Veg = 9 // contador decrementado em 3 unidades 


5.3.2 Estrutura de repetição WHILE 


Trata-se de uma estrutura de repetição que pode ser utilizada quando o número de repetições necessá- 
rias não for fixo. Os comandos serão repetidos até a condição assumir o valor falso. 

Nesse tipo de estrutura, o teste condicional ocorre no início. Isso significa que existe a possibilidade da 
repetição não ser executada quando a condição assumir o valor falso logo na primeira verificação. 


while(condição) 
comando; 


Enquanto a condição for verdadeira, o comando será executado. 


while(condição) 
{ comandol; 
comando? ; 
comando ; 


} 


Enquanto a condição for verdadeira, os comandos que estão dentro das chaves serão executados 
(comando1, comando2, comando3...). 
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Exemplos: 


X = 0; // inicialização da variável x com o valor O 
while (X != 5) 
{ 

printf(“Valor de X = %d”,X); 

Xx=X+ 1; // contador incrementado em 1 unidade 


} 


printf(“Valor de X depois que sair da estrutura = %d"”,X); 


No trecho de programa anterior, os comandos printf (“Valor de X = %d”,X);eX = X + 1; foram 
executados cinco vezes. O teste condicional avalia x valendo 0, 1, 2, 3, 4e 5. 


Simulação: 
TELA X 
o Valor inicial 
Valor de X = O 1 
Valor de X= 1 2 . a 
Valores obtidos dentro da estrutura de repetição 
Valor de X = 2 3 
Valor de X = 3 4 
valordé x+ ä 5 Valor obtido dentro da estrutura de repetição, que 
torna a condição falsa e interrompe a repetição 
Valor de X depois que 
sair da estrutura = 5 
Xx=1; // inicialização da variável X com o valor 1 
Y = 10; // inicialização da variável Y com o valor 10 
while (Y > X) 
{ 


printf(“Valor de Y = %d”,Y); 
Y = Y— 2; // contador decrementado em 2 unidades 
} 


printf(“Valor de Y depois que sair da estrutura = %d",Y); 


No trecho de programa acima, os comandos printf(“Valor de Y = %d”,Y);eY = Y — 2; foram 
executados cinco vezes. O teste condicional avalia y valendo 10, 8, 6,4,2 e0. 


Simulação: 
TELA X Y 
1 10 Valores iniciais 
Valor de Y = 10 1 8 
Valor de Y = 8 1 6 Ê ; 
Valores obtidos dentro da estrutura de repetição 
Valor de Y = 6 1 4 
Valor de Y = 4 1 2 
Valor dey=2 i 0 Va or obtido dentro da estrutura de repetição, que torna a 
condição falsa e interrompe a repetição 
Valor de Y depois que 
sair da estrutura = O 
Xx=1; // inicialização da variável X com o valor 1 
Y=1; // inicialização da variável Y com o valor 1 


while (X < Y) 
{ 
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printf(“Valor de X = 3d”,X); 
X =X + 1; // contador incrementado em 1 unidade 


; 


No trecho de programa anterior, os comandos printf(“valor de X = $d”",X);eX = X + 1; não foram 
executados, pois, com os valores iniciais de x e Y, a condição é falsa; logo, não ocorre a entrada na estrutura 
de repetição para execução de seus comandos. 


5.3.3 Estrutura de repetição DO-WHILE 


Trata-se de uma estrutura de repetição que pode ser utilizada quando o número de repetições necessá- 
rias não for fixo. Os comandos serão repetidos até a condição assumir o valor falso. 

Nesse tipo de estrutura o teste condicional ocorre no fim. Isso significa que a repetição será executada, no 
mínimo, uma vez, quando todo o bloco for executado uma vez, e, ao final, a condição assumir o valor falso. 


do 
{ 


comandos; 


} 


while (condição); 


Os comandos serão repetidos até que a condição assuma valor falso. 


Exemplos: 
XERO, // inicialização da variável X com o valor 0 
do 
{ 


printf(“Valor de X = %d”,X); 
X =X + 1; // contador incrementado em 1 unidade 


} 
while (X != 5); 
printf(“Valor de X depois que sair da estrutura = 3d”,X); 


No trecho de programa anterior, os comandos printf (“valor de X = %d”,X); eX = x + 1; foram 
executados cinco vezes. O teste condicional avalia x valendo 1, 2, 3,4 e 5. 


Simulação: 
TELA X 
0 Valor inicial 
Valor de X = 0 1 
Valor de X= 1 2 j ; 
Valores obtidos dentro da estrutura de repetição 
Valor de X = 2 3 
Valor de X = 3 4 
Valor de X= 4 5 Valor obtido dentro da estrutura de repetição, que 
torna a condição falsa e interrompe a repetição 
Valor de X depois que 
sair da estrutura = 5 
K = ig // inicialização da variável X com o valor 1 
Y = 10; // inicialização da variável Y com o valor 10 
do 
{ 


printf(“Valor de Y = %d”,Y); 

Y = Y — 2; // decrementando o contador em 2 unidades 
} 
while (Y > X); 
printf(“Valor de Y depois que sair da estrutura = %d",Y); 
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No trecho de programa anterior, os comandos printf (“Valor de Y = Sd”,Y);eY = Y — 2; são exe- 
cutados cinco vezes. O teste condicional avalia y valendo 8, 6, 4, 2 e 0. 


Simulação: 
TELA X Y 
1 10 Valores iniciais 

Valor de Y = 10 1 8 

Valor de Y = 8 1 6 ` ; 
Valores obtidos dentro da estrutura de repetição 

Valor de Y = 6 1 4 

Valor de Y = 4 1 2 

Valor de Y=2 i 0 Valor obtido dentro da estrutura de repetição, que torna a 
condição falsa e interrompe a repetição 


Valor de Y depois que 
sair da estrutura = O 


5.4 Estrutura de repetição em JAVA 


5.4.1 Estrutura de repetição FOR 


Essa estrutura de repetição é utilizada quando se sabe o número de vezes que um trecho do programa 
deve ser repetido. 


O formato geral do comando FoR é composto por três partes: 


for (i=valor inicial; condição; incremento ou decremento de i) 
comando; 


A primeira parte atribui um valor inicial à variável i, que tem como função controlar o número 
necessário de repetições. 

A segunda parte corresponde a uma expressão relacional que, quando assumir o valor falso, determi- 
nará o fim da repetição. 

A terceira parte é responsável por alterar o valor da variável i (incremento ou decremento) com o ob- 
jetivo de, em algum momento, fazer a condição assumir o valor falso. 

Caso seja necessária a repetição de apenas um comando, o compilador entenderá que a estrutura de 
repetição terminará quando for encontrado o primeiro ; (ponto e vírgula). 


Exemplo: 


for (a=l;a<=20,a++) 
System.out.println(“O valor de a é: “ +a); 


No exemplo anterior, a variável a é inicializada com o valor 1 (a=1) e é incrementada em uma unidade 
(a++). A cada incremento, o comando system. out .printIn é executado. Esse processo se repete até o valor da 
variável a se tornar maior que 20 (quando a condição a <= 20 assumir o valor falso). 

Se for necessária a repetição de mais de um comando, a linguagem entenderá que a estrutura de repeti- 
ção começará quando for encontrado o símbolo { e terminará quando for encontrado o símbolo ). 


Exemplo: 


for (a=15;a>=1;a=a-2) 
f 
System.out.println(“Digite um número: “); 
dado = new Scanner(System.in); 


x = dado.nextInt(); 
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No exemplo anterior, a variável a começa com o valor 15 (a=15) e é decrementada em duas unidades 
(a=a-2). A cada decremento, o bloco de comando que está entre chaves { ... ) é executado. Esse processo se 
repete até o valor da variável a se tornar menor que 1 (quando a condição a >= 1 assumir o valor falso). 


Exemplos: 


for (at = dl a SA 59 das) 
System.out.println(i); 

ou 

Ford (= ac) 
System.out.println(i); 


Nos trechos de programa anteriores, que apesar de utilizarem formas diferentes para aumentar o valor 
da variável i, expressam a mesma coisa, o comando system.out.println(i); foi executado cinco vezes, 
ou seja, para i valendo 1, 2, 3,4 e 5. 


for (1 =o n =D) 
System.out.println(i); 


ou 
for (i = 10; i >= 1; i=i-l) 
System.out.println(i); 


Nos trechos de programa anteriores, apesar de utilizarem formas diferentes para diminuir o valor da 


variável i, são exatamente a mesma coisa, o comando System.out .printlIn(i); foi executado dez vezes, 
ou seja, para i valendo 10,9,8,7,6,5,4,3,2€e1. 


for (i = 0; i <= 10; i=i+2) 
System.out.println(i); 


No trecho de programa anterior, o comando System.out.printIn(i); foi executado seis vezes, ou 
seja, para i valendo 0, 2, 4, 6, 8 e 10. 


for (i = 100; i >= 0; i=i-20) 
System.out.println(i); 


No trecho de programa acima, o comando system.out .println(i); foi executado seis vezes, ou seja, 
para i valendo 100, 80, 60, 40, 20 e 0. 

Existem duas instruções comumente usadas nos comandos internos das estruturas de repetição. São as 
instruções denominadas acumuladores e contadores. 

Os acumuladores devem ser usados quando a realização de um cálculo precisa de valores obtidos a cada 
iteração, ou seja, o cálculo só estará concluído com a conclusão da repetição. É por isso que um acumulador 
deve ser inicializado com um valor neutro para a operação em que será utilizado. Por exemplo, se for usado 
em uma adição, deve ser inicializado com zero; se for usado em uma multiplicação, deve ser inicializado com 1. 


Exemplo de acumulador: 


SOMA = 0; // inicialização da variável SOMA com o valor zero 
for(i di e po EEE) 

{ 

System.out.print(“Digite um número: “); 


NUM = dado.nextInt(); 
SOMA = SOMA + NUM; // acumulando o valor da variável NUM na variável soma 


} 
System.out.println (“Soma = "+SOMA); 
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Simulação: 
MEMÓRIA TELA 
| NUM SOMA 
0 Inicialização da variável SOMA com o valor zero 
SOMA = 0; 
1 Digite um número: 5 
1 5 
i 5 E Acumulando o valor da variável NUM na variável SOMA 
SOMA = SOMA + NUM; 
Digite um número: 3 
5 
> 3 8 Acumulando o valor da variável NUM na variável SOMA 
SOMA = SOMA + NUM; 
Digite um número: O 
0 
3 0 8 Acumulando o valor da variável NUM na variável SOMA 
SOMA = SOMA + NUM; 
4 Digite um número: 10 
10 
"i 10 18 Acumulando o valor da variável NUM na variável SOMA 
SOMA = SOMA + NUM; 
Digite um número: 2 
2 
5 > 50 Acumulando o valor da variável NUM na variável SOMA 


SOMA = SOMA + NUM; 
Soma = 20 


Exemplo de contador: 


CONT = 0; // inicialização da variável CONT com o valor zero 
forr = = EEE) 
{ 


System.out.print(“Digite um número: “); 
NUM = dado.nextInt(); 
if (NUM > 5) 
CONT = CONT + 1; // contando mais 1 na variável CONT 
} 


System.out.println(“Quantidade de número maiores que 5 = "+ CONT); 


Simulação: 
MEMÓRIA TELA 
| NUM CONT 
0 Inicialização da variável CONT com o valor zero 

CONT=0; 
1 Digite um número: 5 
1 5 
| 5 0 O número digitado não é maior que 5, logo, o contador 

CONT não será alterado 
2 Digite um número: 12 
2 12 


O número digitado é maior que 5, logo, o contador 
2 12 1 CONT será incrementado em 1 unidade 
CONT = CONT + 1; 
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MEMÓRIA TELA 
| NUM CONT 
3 Digite um número: 8 
3 8 
O número digitado é maior que 5, logo, o contador 
S 8 2 CONT será incrementado em 1 unidade 
CONT = CONT + 1; 
4 Digite um número: 3 
4 5 
a z > O número digitado não é maior que 5, logo, o contador 
CONT não será alterado 
5 Digite um número: 6 
5 6 
O número digitado é maior que 5, logo, o contador 
5 6 3 CONT será incrementado em 1 unidade 


CONT = CONT + 1; 


Quantidade de números 
maiores que 5 = 3 


A terceira parte da estrutura de repetição FOR é um contador que pode ser incrementado ou decrementado. 


Exemplos: 

I=I+ l; // contador incrementado em 1 unidade 

I++; // contador incrementado em 1 unidade 

Iere // contador decrementado em 1 unidade 

Teo // contador decrementado em 1 unidade 

I=I+2; // contador incrementado em 2 unidades 
Jsi // contador decrementado em 3 unidades 


5.4.2 Estrutura de repetição WHILE 


Trata-se de uma estrutura de repetição que pode ser utilizada quando o número de repetições necessá- 
rias não for fixo. Os comandos serão repetidos até a condição assumir o valor falso. 

Nesse tipo de estrutura o teste condicional ocorre no início, o que significa que existe a possibilidade da 
repetição não ser executada quando a condição assumir o valor falso logo na primeira verificação. 


while (condição) 
comando; 
Enquanto a condição for verdadeira, o comando será executado. 


while (condição) 
{ comandol ; 
comando? ; 


comando3; 


} 


Enquanto a condição for verdadeira, os comandos que estão dentro das chaves serão executados (co- 
mando1, comando2, comando3...). 


Exemplos: 


X = 0; // inicialização da variável X com o valor 0 
while (X != 5) 
{ 
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System.out.println(“Valor de X = “+X); 
x =x + 1; // contador incrementado em 1 unidade 


} 


System.out.println(“Valor de X depois que sair da estrutura = “+X); 


No trecho de programa anterior, os comandos System.out.printin(“valor de X = “+X);eX = X + 1; 
foram executados cinco vezes. O teste condicional avalia x valendo 0, 1, 2, 3, 4e 5. 


Simulação: 
TELA X 
0 Valor inicial 
Valor de X= 0 1 
Valor de X= 1 2 : alo 
lorde X23 3 Valores obtidos dentro da estrutura de repetição 
Valor de X= 3 4 
Yord Xx=4 E Valor obtido dentro da estrutura de repetição, que 
torna a condição falsa e interrompe a repetição 
Valor de X depois que 
sair da estrutura = 5 
= ig // inicialização da variável X com o valor 1 
Y = 10; // inicialização da variável Y com o valor 10 
while (Y > X) 
{ 


System.out.println(“Valor de Y = “+Y); 
Y = Y — 2; // contador decrementado em 2 unidades 


} 


System.out.println(“Valor de Y depois que sair da estrutura = “+Y); 


No trecho de programa anterior, os comandos system.out.println(“Valor de Y = “+Y);eY = Y — 2; 
são executados cinco vezes. O teste condicional avalia y valendo 10, 8, 6, 4, 2 e 0. 


TELA X Y 
1 10 Valores iniciais 
Valor de Y = 10 1 8 
Valor de Y = 8 1 6 y ; 
Valores obtidos dentro da estrutura de repetição 
Valor de Y = 6 1 4 
Valor de Y = 4 1 2 
ndeas i 0 Va or obtido dentro da estrutura de repetição, que torna a 
condição falsa e interrompe a repetição 
Valor de Y depois que 
sair da estrutura = O 
Xx=1; // inicialização da variável X com o valor 1 
Y=1; // inicialização da variável Y com o valor 1 
while (X < Y) 
{ 
System.out.println(“Valor de X = “+X); 
X=X+1; // contador incrementado em 1 unidade 
> 


No trecho de programa, os comandos System.out.println(“Valor de X = “+X);€X = X + 1; não 
serão executados, pois com os valores iniciais de x e Y a condição é falsa. Logo, não ocorrerá a entrada na 
estrutura de repetição para execução dos seus comandos. 
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5.4.3 Estrutura de repetição DO-WHILE 


Trata-se de uma estrutura de repetição que pode ser utilizada quando o número de repetições neces- 
sárias não for fixo. Os comandos serão repetidos até a condição assumir o valor falso. 

Nesse tipo de estrutura o teste condicional ocorre no fim. Isso significa que a repetição será executa- 
da, no mínimo, uma vez, quando todo o bloco for executado uma vez, e, ao final, a condição assumir o 
valor falso. 


do 
{ 


comandos; 


} 


while (condição); 


Os comandos serão repetidos até que a condição assuma o valor falso. 


Exemplos: 
X= 0; // inicialização da variável X com o valor 0 
do 
{ 


System.out.println(“Valor de X = “ +X); 
Xx=X+ 1; // contador incrementado em 1 unidade 


} 
while (X != 5); 
System.out.println(“Valor de X depois que sair da estrutura = “+X); 


No trecho de programa anterior, os comandos System.out.println (“Valor de X = “+X);eX =X + 
1; foram executados cinco vezes. O teste condicional avalia x valendo 1, 2, 3,4 e 5. 


TELA X 
0 Valor inicial 

Valor de X= O 1 

Valor de X = 1 2 , . 
Valores obtidos dentro da estrutura de repetição 

Valor de X= 2 3 

Valor de X=3 4 

ValordéX=4 5 Valor obtido dentro da estrutura de repetição, que 
torna a condição falsa e interrompe a repetição 

Valor de X depois que 


sair da estrutura = 5 


// inicialização da variável X com o valor 1 
// inicialização da variável Y com o valor 10 


K x 
No 
HH 
E sa 


System.out.println(“Valor de Y =“ + Y); 
Y = Y — 2; // contador decrementado em 2 unidades 


} 
while (Y > X); 
System.out.println(“Valor de Y depois que sair da estrutura = “ + Y); 


No trecho de programa anterior, os comandos System.out.println (“Valor de Y =“ + Y);eY =Y 
— 2; foram executados cinco vezes. O teste condicional avalia y valendo 8, 6, 4, 2 e 0. 
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Simulação: 


TELA 
Valor de Y = 10 
Valor de Y = 8 
Valor de Y = 6 
Valor de Y = 4 
Valor de Y = 2 


Valor de Y depois que 


sair da estrutura = 


0 


EXERCÍCIOS RESOLVIDOS 


Y 
10 Va 
8 
É Va 
4 
2 
0 Va 


co 


ores iniciais 


ores obtidos dentro da estrutura de repetição 


or obtido dentro da estrutura de repetição, que torna a 


ndição verdadeira e interrompe a repetição 


EEB Um funcionário de uma empresa recebe, anualmente, aumento salarial. Sabe-se que: 
a) Esse funcionário foi contratado em 2005, com salário inicial de R$ 1.000,00. 


b) Em 2006, ele recebeu aumento de 1,5% sobre seu salário inicial. 


c) A partir de 2007 (inclusive), os aumentos salariais sempre corresponderam ao dobro do percentual do ano 
anterior. 


Faça um programa que determine o salário atual desse funcionário. 


(AILISIOJRL TIM) Solução: 


ALGORITMO 
DECLARE i, ano atual, salario NUMÉRICO 

novo salario, percentual NUMÉRICO 
LEIA ano atual 


salario 


— 1000 


percentual — 1.5/100 
novo salario + salario + percentual * salario 
PARA i < 2007 ATÉ ano atual FAÇA 


INÍCIO 


percentual — 


2 * percentual 


novo salario + novo salario + percentual * novo salario 


FIM 


ESCREVA novo salario 
FIM ALGORITMO. 


PASCAL 
D 


C/C++ 
D 

JAVA 
CED 


12 soLução — UT 


\EXERC\CAP5 


22 SOLUÇÃO — UT 


\EXERC\CAP5 
12 soLução — u 
\EXERC\CAP5 
22 SOLUÇÃO — U 
\EXERC\CAP5 
12 soLução — u 


\EXERC\CAP5 


22 SOLUÇÃO — U 


LIZAN 


LIZAN 


LIZAN 


LIZAN 


\JAVA\EX1_A. 


DO A ESTRUT 


DO A ESTRUT 


CALNEX1 


DO A ESTRUT 


DO A ESTRUT 


DO A ESTRUT 


DO A ESTRUT 


Ra FOR: 


RA WHILE: 


Ra FOR: 


Ra WHILE: 


Ra FOR: 


Ra WHILE: 


CALVEX1 A.PAS e NEXERCICAP5IPASCALNEX1 A.EXE 


_B.PAS e NEXERCICAP5SPASCALNEX1 B.EXE 


\C++\EX1_A.CPP e \EXERC\CAP5\C++\EX1_A.EXE 


\C++\EX1_B.CPP e \EXERC\CAP5\C++\EX1_B.EXE 


java e \EXERC\CAP5\JAVA\EX1_A.class 


\EXERC\CAP5\JAVA\EX1_B.java e \EXERC\CAP5\JAVA\EX1_B.class 
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IFA Faça um programa que leia um valor N inteiro e positivo. Calcule e mostre o valor de E, conforme a 
fórmula a seguir: 


E=1+1/11 + 1/21 +1/3! +... + 1/N! 
(ALLISIOJRLITIMIO) Sorução: 


ALGORITMO 
DECLARE n, e, i, j, fat NUMÉRICO 
LEIA n 
ec 1 
PARA i — 1 ATÉ n FAÇA 
INÍCIO 
fat — 1 
PARA j — 1 ATÉ i FAÇA 
INÍCIO 
fat — fat * 5 
FIM 
e—e+l/fat 
FIM 
ESCREVA e 
FIM ALGORIMO. 


I NS{o NH 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ed) NEXERCNCAPS VPASCALVEX2 A.PAS e VEXERCICAP5SYPASCALNEX2 A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 


\EXERC\CAP5\PASCAL\EX2_B.PAS e NEXERCICAP5SIPASCALNEX2 B.EXE 
LETTA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\C++\EX2_A.CPP e\EXERC\CAP5\C++\EX2_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX2_B.CPP e \EXERC\CAP5\C++\EX2_B.EXE 


BAIA 1? soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
(m \EXERC\CAP5\JAVA\EX2_A. java e \EXERC\CAP5\JAVA\EX2_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\JAVA\EX2_B.java e \EXERC\CAP5\JAVA\EX2_B.class 


EJ Faça um programa que leia um número N que indica quantos valores inteiros e positivos devem ser 
lidos a seguir. Para cada número lido, mostre uma tabela contendo o valor lido e o fatorial desse valor. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE n, num, i, j, fat NUMÉRICO 
LEIA n 
PARA i — 1 ATÉ n FAÇA 
INÍCIO 
LEIA num 
fat — 1 
PARA j — 1 ATÉ num FAÇA 
INÍCIO 
fat — fat * 5 
FIM 
ESCREVA fat 
FIM 


FIM ALGORITMO. 
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INSA A 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
Ens \EXERC\CAP5\PASCAL\EX3_A.PAS e \EXERC\CAP5\PASCAL\EX3_A. EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\PASCAL\EX3_B.PAS e \EXERC\CAP5\PASCAL\EX3_B. EXE 


VLE TTA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 


\EXERC\CAP5\C++\EX3_A.CPP e NEXERCICAP5SÍCHNEX3 A. EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX3_B.CPP e \EXERC\CAP5\C++\EX3_B.EXE 


NE-AI- 1? soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 


\EXERC\CAP5\JAVA\EX3_A.java e \EXERC\CAP5\JAVA\EX3_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\JAVA\EX3_B.java e \EXERC\CAP5\JAVA\EX3_B.class 


IJ Foi feita uma estatística em cinco cidades brasileiras para coletar dados sobre acidentes de trânsito. 
Foram obtidos os seguintes dados: 
a) código da cidade; 
b) número de veículos de passeio; 
c) número de acidentes de trânsito com vítimas. 


Deseja-se saber: 

a) qual é o maior e qual é o menor índice de acidentes de trânsito e a que cidades pertencem; 
b) qual é a média de veículos nas cinco cidades juntas; 

c) qual é a média de acidentes de trânsito nas cidades com menos de 2.000 veículos de passeio. 


(AILIGIOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE cont, cod, num vei, num acid NUMÉRICO 
maior, cid maior, menor, cid menor NUMÉRICO 
media vei, soma vei, media acid NUMÉRICO 
soma acid, cont acid NUMÉRICO 
soma vei — 0 
soma acid — 0 
cont acid — 0 
PARA cont + 1 
INÍCIO 
LEIA cod, num vei, num acid 
SE cont = 1 
ENTÃO INÍCIO 
maior — num acid 
cid maior — cod 
menor — num acid 
cid menor — cod 
FIM 
SENÃO INÍCIO 
SE num acid > maior 
ENTÃO INÍCIO 
maior — num acid 
cid maior — cod 
FIM 
SE num acid < menor 
ENTÃO INÍCIO 
menor — num acid 


ATÉ 5 FAÇA 
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cid menor — cod 
FIM 
FIM 
soma vei — soma vei + num vei 
SE num vei < 2000 
ENTÃO INÍCIO 
soma acid <— soma acid + num acid 
cont acid — cont acid + 1 
FIM 
FIM 
ESCREVA maior, cid maior 
ESCREVA menor, cid menor 
media vei — soma vei/5 
ESCREVA media vei 
SE cont acid = 0 
ENTÃO ESCREVA “Não foi digitada nenhuma cidade com menos de 2000 veículos” 
SENÃO INÍCIO 
media acid — soma acid/cont acid 
ESCREVA media acid 
FIM 
FIM ALGORITMO. 


INSA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) NEXERCNCAPS VPASCALVEX4 A.PAS e \EXERC\CAP5\PASCAL\EX4 A.EXE 


2º SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX4_B.PAS e NEXERCICAP5SIPASCALVEX4 B.EXE 


LETT 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\C++\EX4_A.CPP e \EXERC\CAP5\C++\EX4_A.EXE 
2º SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX4_B.CPP e \EXERC\CAP5\C++\EX4_B.EXE 


MS-GS- 1? soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
(C) \EXERC\CAP5 \JAVA\EX4_A.java e \EXERC\CAP5\JAVA\EX4_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX4_B.java e \EXERC\CAP5\JAVA\EX4_B.class 


REA Faça um programa que leia o número de termos e um valor positivo para X. Calcule e mostre o valor 
da série a seguir: 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE fim, i, j, X, expoente, num termos NUMÉRICO 
den, denominador, fat, SNUMÉRICO 
LEIA num termos,x 
S — 0 
denominador — 1 
PARA i — 1 TO num termos FAÇA 
INÍCIO 
fim — denominador 
eNe o d 
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PARA j — 1 ATÉ fim FAÇA 
INÍCIO 
fat — fat * j 
FIM 
expoente — i+1l 
SE RESTO (expoente/2) =0 
ENTÃO s — s — x expoente /fat 
SENÃO s — s + x expoente /fat 
SE denominador = 4 
ENTÃO den — -1 
SE denominador =1 
ENTÃO den <1 
SE den= 1 
ENTÃO denominador denominador + 1 
SENÃO denominador +-denominador — 1 
FIM 
ESCREVA s 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\PASCAL\EX5_A.PAS e \EXERC\CAP5\PASCAL\EX5_A. EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\PASCAL\EX5_B.PAS e \EXERC\CAP5\PASCAL\EX5_B. EXE 


VLE TA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\C++\EX5_A.CPP e \EXERC\CAP5\C++\EX5_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX5_B.CPP e \EXERC\CAP5\C++\EX5_B.EXE 


RBWIM 1? soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) \EXERC\CAP5\JAVA\EX5_A. java e \EXERC\CAP5\JAVA\EX5_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\JAVA\EX5_B.java e \EXERC\CAP5\JAVA\EX5_B.class 


EA Uma empresa possui dez funcionários com as seguintes características: código, número de horas traba- 
lhadas no mês, turno de trabalho (M — matutino; V — vespertino; ou N — noturno), categoria (O — 
operário; ou G — gerente), valor da hora trabalhada. Sabendo-se que essa empresa deseja informatizar 
sua folha de pagamento, faça um programa que: 

a) Leia as informações dos funcionários, exceto o valor da hora trabalhada, não permitindo que sejam informa- 
dos turnos e nem categorias inexistentes. Trabalhe sempre com a digitação de letras maiúsculas. 

b) Calcule o valor da hora trabalhada, conforme a tabela a seguir. Adote o valor de R$ 450,00 para o salário 
minimo. 


CATEGORIA TURNO VALOR DA HORA TRABALHADA 
G N 18% do salário mínimo 
G M ou V 15% do salário mínimo 
O N 13% do salário mínimo 
O M ou V 10% do salário mínimo 


Calcule o salário inicial dos funcionários com base no valor da hora trabalhada e no número de horas traba- 
lhadas. 

d) Calcule o valor do auxílio alimentação recebido pelo funcionário de acordo com seu salário inicial, conforme 
a tabela a seguir. 


Q 
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SALÁRIO INICIAL 
Até R$ 300,00 
Entre R$ 300,00 e R$ 600,00 
Acima de R$ 600,00 


e) Mostre o código, número de horas trabalhadas, valor da hora trabalhada, salário inicial, auxílio alimentação 


e salário final (salário inicial + auxílio alimentação). 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE cont, codigo, nht, valor NUMÉRICO 


AUXÍLIO ALIMENTAÇÃO 
20% do salário inicial 
15% do salário inicial 
5% do salário inicial 


sal min, sal inicial, aux, sal final NUMÉRICO 


turno, categoria LITERAL 
sal min — 450 
PARA cont — 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA codigo, nht, turno, categoria 


ENQUANTO turno * “M” E turno * “V” E turno * “N” FAÇA 


INÍCIO 
LEIA turno 
FIM 
ENQUANTO categoria = “G” E categoria = “O” FAÇA 
INÍCIO 
LEIA categoria 
FIM 
SE categoria = “G” 
ENTÃO INÍCIO 
SE turno = “N” 
ENTÃO valor + sal min * 18/100 
SENÃO valor — sal min * 15/100 
FIM 
SENÃO INÍCIO 
SE turno = “N” 
ENTÃO valor + sal min * 13/100 
SENÃO valor + sal min * 10/100 


FIM 
sal inicial — nht * valor 
SE sal inicial <= 300 
ENTÃO aux — sal inicial * 20/100 
SENÃO SE sal inicial < 600 


ENTÃO aux + sal inicial * 15/100 
SENÃO aux + sal inicial * 5/100 


sal final — sal inicial + aux 


ESCREVA codigo, nht, valor, sal inicial, aux, sal final 


FIM 
FIM ALGORITMO. 


INSNI 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
D \EXERC\CAP5\PASCAL\EX6_A.PAS e \EXERC\CAP5\PASCAL\EX6_A. EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 


\EXERC\CAP5\PASCAL\EX6_B.PAS e \EXERC\CAP5\PASCAL\EX6_B.EXE 
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[e)AeR TSA 1º soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ed) NEXERCNCAPS \C++\EX6_A.CPP e \EXERC\CAP5\C++\EX6_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\C++\EX6_B.CPP e \EXERC\CAP5\C++\EX6_B.EXE 


PEGA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) \EXERC\CAP5\JAVA\EX6_A. java e \EXERC\CAP5\JAVA\EX6_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\JAVA\EX6_B.java e \EXERC\CAP5\JAVA\EX6_B.class 


IEA Faça um programa que monte os oito primeiros termos da sequência de Fibonacci. 


0-1-1-2-3-5-8-13-21-34-55... 


(AILTSIOJRN TIM) Sorução: 


ALGORITMO 
DECLARE cont, numl, num2, res NUMÉRICO 
numi <— 0 
num? + 1 
ESCREVA numl 
ESCREVA num2 
PARA cont — 3 ATÉ 8 FAÇA 
INÍCIO 
res — numi + num2 
ESCREVA res 
numi <— num2 
num2 <— res 
FIM 
FIM ALGORITMO. 


INNA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) NEXERCNCAPS VPASCALVEX7 A.PAS e VEXERCICAP5SYPASCALNEX7 A.EXE 


2º SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX7_B.PAS e NEXERCACAP5SIPASCALNEX7 B.EXE 


[e)AenHA 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) NEXERCNCAPS NC++NEX7 A.CPP e \EXERC\CAP5\C++\EX7_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE.: 


\EXERC\CAP5\C++\EX7_B.CPP e \EXERC\CAP5\C++\EX7_B.EXE 


PEGA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) NEXERCNCAPSNJAVANEX7 A. java e \EXERC\CAP5\JAVA\EX7_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE.: 
\EXERC\CAP5\JAVA\EX7_B.java e VEXERCICAPSIJAVANEX7 B.class 


REA Faça um programa que leia o número de termos, determine e mostre os valores de acordo com a série 
a seguir: 


Sis = 2, dp tp Vl MP, do 3 do, do, SO, OZ, SA, SO, Us 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE i, num termos, numl, num2, num3 NUMÉRICO 
LEIA num termos 
numi <— 2 
num? <— 7 
num3 — 3 
ESCREVA numl 
ESCREVA num2 
ESCREVA num3 
i—a4 
enquanto i * num termos FAÇA 
INÍCIO 
numi <— numi * 2 
ESCREVA numl 
i — i+1 
SE i * num termos 
ENTÃO INÍCIO 
num? — num2 * 3 
ESCREVA num2 
i — i+1 
SE i É num termos 
ENTÃO INÍCIO 
num3 <— num3 * 4 
ESCREVA num3 
i — i+il 
FIM 
FIM 
FIM 
FIM ALGORITMO. 


ij NS{0 A 1º soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) NEXERCNCAPS VPASCALVEX8 A.PAS e VEXERCICAP5SYPASCALNEX8 A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 


\EXERC\CAP5\PASCAL\EX8_B.PAS e \EXERC\CAP5\PASCAL\EX8_B.EXE 
VLE TSA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX8_A.CPP e \EXERC\CAP5\C++\EX8_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\C++\EX8_B.CPP e \EXERC\CAP5\C++\EX8_B.EXE 


BAIANA 1? soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) \EXERC\CAP5\JAVA\EX8_A. java e \EXERC\CAP5\JAVA\EX8_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\JAVA\EX8_B.java e \EXERC\CAP5\JAVA\EX8_B.class 


J Faça um programa que receba duas notas de seis alunos. Calcule e mostre: 
a média aritmética das duas notas de cada aluno; e 


a mensagem que está na tabela a seguir: 
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MÉDIA ARITMÉTICA MENSAGEM 
Até 3 Reprovado 
Entre 3 e 7 Exame 
De 7 para cima Aprovado 


o total de alunos aprovados; 
o total de alunos de exame; 
o total de alunos reprovados; 
a média da classe. 


(AILISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE cont, nl, n2, media, ta, te, tr NUMÉRICO 
media classe, total classe NUMÉRICO 
total classe + 0 
PARA cont — 1 ATÉ 6 FAÇA 
INÍCIO 
LEIA nl, n2 
media — (nl + n2) /2 
ESCREVA media 
SE media <= 3 
ENTÃO INÍCIO 
Jens SE quo a dl 
ESCREVA “Reprovado” 
FIM 
SE media > 3 E media < 7 
ENTÃO INÍCIO 
te — te + 1 
ESCREVA “Exame” 
FIM 
SE media >= 7 
ENTÃO INÍCIO 
ta — ta + 1 
ESCREVA “Aprovado” 


FIM 
total classe — total classe + media 
FIM 
ESCREVA tr 
ESCREVA te 
ESCREVA ta 


media classe — total classe/6 
ESCREVA media classe 
FIM ALGORITMO. 


INNA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\PASCAL\EX9_A.PAS e NEXERCICAP5SAPASCALNEX9 A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\PASCAL\EX9_B.PAS e NEXERCACAP5SIPASCALNEX9 B.EXE 


VLE RM 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
a \EXERC\CAP5\C++\EX9_A.CPP e \EXERC\CAP5\C++\EX9_A.EXE 
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22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\C++\EX9_B.CPP e \EXERC\CAP5\C++\EX9_B.EXE 


BAIANO] 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
(C) NEXERCNCAPS NJAVANEX9 A.java e NEXERCICAP5SJAVANEX9 A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


VEXERCICAP5SNJAVANEX9 B.java e \EXERC\CAP5\JAVA\EX9_B.class 


ELA Em um campeonato de futebol existem cinco times e cada um possui onze jogadores. Faça um progra- 
ma que receba a idade, o peso e a altura de cada um dos jogadores, calcule e mostre: 


a quantidade de jogadores com idade inferior a 18 anos; 

a média das idades dos jogadores de cada time; 

a média das alturas de todos os jogadores do campeonato; e 

a porcentagem de jogadores com mais de 80 kg entre todos os jogadores do campeonato. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE cont time, cont jog, idade NUMÉRICO 
peso, alt, qtde, media idade NUMÉRICO 
media altura, porc, tot80 NUMÉRICO 
qtde — 0 
tot80 — 0 
PARA cont time — 1 ATÉ 5 FAÇA 
INÍCIO 
media idade — 0 
PARA cont jog <— 1 ATÉ 11 FAÇA 
INÍCIO 
leia idade, peso, alt 
SE idade < 18 
ENTÃO qtde — qtde + 1 
media idade + media idade + idade 
media altura « media altura + alt 
SE peso > 80 
ENTÃO tot80 — tot80 + 1 
FIM 
media idade 
ESCREVA media idade <+ media idade/11 
FIM 
ESCREVA qtde 
media altura <— media altura/55 
ESCREVA media altura 
porc — tot80 * 100/55 
ESCREVA porc 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ad) NEXERCNCAPS VPASCALNEX10 A.PAS e \EXERC\CAP5\PASCAL\EX10_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\PASCAL\EX10_B.PAS e NEXERCICAP5SPASCALNEX10 B.EXE 


PAGE RM 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) VEXERCNCAP5SNC++NEX10 A.CPP e \EXERC\CAP5\C++\EX10_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX10_B.CPP e \EXERC\CAP5\C++\EX10_B.EXE 
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BAIANO 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ed) NEXERCNCAPSNJAVANEX1 O A.java e \EXERC\CAP5\JAVA\EX10_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\JAVA\EX10_B.java e \EXERC\CAP5\JAVA\EX10_B.class 


EEB Faça um programa que receba um número inteiro maior que 1, verifique se o número fornecido é pri- 
mo ou não e mostre uma mensagem de número primo ou de número não primo. 
Um número é primo quando é divisível apenas por 1 e por ele mesmo. 


(AILISIOJRI ITIMO) Sorução: 


ALGORITMO 

DECLARE i, num, qtde NUMÉRICO 

LEIA num 

qtde — 0 

PARA i — 1 ATÉ num FAÇA 
INÍCIO 


SE RESTO(num/i) = 0 
ENTÃO qtde — qtde + 1 
FIM 
SE qtde > 2 
ENTÃO ESCREVA “Número não primo” 
SENÃO ESCREVA “Número primo” 
FIM ALGORITMO. 


NeoN 12 soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) NEXERCNCAPS VPASCALVEX11 A.PAS e NEXERCICAP5SAPASCALNEX11 A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX11_B.PAS e NEXERCICAP5SPASCALNEX11 B.EXE 


VLET 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ed) NEXERCNCAPS \C++\EX11_A.CPP e \EXERC\CAP5\C++\EX11_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\C++\EX11_B.CPP e \EXERC\CAP5\C++\EX11_B.EXE 
E-G 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
D \EXERC\CAP5\JAVA\EX11_A.java e \EXERC\CAP5\JAVA\EX11_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX11_B.java e \EXERC\CAP5\JAVA\EX11_B.class 


EFA Em uma fábrica trabalham homens e mulheres divididos em três classes: 
trabalhadores que fazem até 30 peças por mês — classe 1; 
trabalhadores que fazem de 31 a 50 peças por mês — classe 2; 


trabalhadores que fazem mais de 50 peças por mês — classe 3. 

A classe 1 recebe salário mínimo. A classe 2 recebe salário mínimo mais 3% deste salário por peça, 
acima das 30 peças iniciais. A classe 3 recebe salário mínimo mais 5% desse salário por peça, acima das 30 
peças iniciais. 

Faça um programa que receba o número do operário, o número de peças fabricadas no mês, o sexo do 
operário, e que também calcule e mostre: 

o número do operário e seu salário; 
o total da folha de pagamento da fábrica; 


o número total de peças fabricadas no mês; 
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a média de peças fabricadas pelos homens; 
a média de peças fabricadas pelas mulheres; e 


o número do operário ou operária de maior salário. 
A fábrica possui 15 operários. 
(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE num op, pecas op, num maior, cont m, cont f NUMÉRICO 
tot pecas, cont, media m, salario maior NUMÉRICO 
media £, salario op, tot folha NUMÉRICO 
sexo op LITERAL 
tot folha <— 0 
tot pecas + 0 
media m — 0 
media £f — 0 
cont m <— 0 
cont f <— 0 
PARA cont — 1 ATÉ 15 FAÇA 
INÍCIO 
ESCREVA “Digite o número do “, cont, “° operário “ 
LEIA num op 
ESCREVA “Digite o sexo do operário (M ou F) ” 
LEIA sexo op 
ESCREVA “Digite o total de peças fabricadas pelo “, cont, “° operário ” 
LEIA pecas op 
SE pecas op <= 30 
ENTÃO salario op — 450 
SE pecas op > 30 E pecas op <= 50 
ENTÃO salario op — 450 + ((pecas op-30) * 3 / 100 * 450) 
SE pecas op > 50 
ENTÃO salario op — 450 + ((pecas op-30) * 5 / 100 * 450) 
ESCREVA “O operário de número “, num op, “ recebe salário = “, salario op 
tot folha — tot folha + salario op 
tot pecas <— tot pecas + pecas op 
SE sexo op = “M” 
ENTÃO INÍCIO 
media m — media m + pecas op 
cont m < cont m+ 1 
FIM 
SENÃO INÍCIO 
media f « media f + pecas op 
Come dit + Cloe dr a d 
FIM 
SE cont = 1 
ENTÃO INÍCIO 
salario maior <— salario op 
num maior <— num op 
FIM 
SENÃO INÍCIO 
SE (salario op > salario maior) 
ENTÃO INÍCIO 
salario maior <— salario op 
num maior +— num op 
FIM 
FIM 
FIM 
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ESCREVA “Total da folha de pagamento = ”, tot folha 
ESCREVA “Total de peças fabricadas no mês = “,tot pecas 
SE cont m = 0 
ENTÃO ESCREVA “NENHUM HOMEM” 
SENÃO INÍCIO 
media m — media m / cont m 
ESCREVA “Média de peças fabricadas por homens = “”, media m 
FIM 
SE cont f = 0 
ENTÃO ESCREVA “NENHUMA MULHER” 
SENÃO INÍCIO 
media £f — media f / cont £ 
ESCREVA “Média de peças fabricadas por mulheres = “,media f 
FIM 
ESCREVA “O número do operário com maior salário é ”,num maior 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
CE \EXERC\CAP5\PASCAL\EX12_A.PAS e \EXERC\CAP5\PASCAL\EX12_A. EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\PASCAL\EX12_B.PAS e \EXERC\CAP5\PASCAL\EX12_B.EXE 


FLESTA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
cD \EXERC\CAP5\C++\EX12_A.CPP e \EXERC\CAP5\C++\EX12_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX12_B.CPP e \EXERC\CAP5\C++\EX12_B.EXE 


NE-AI 1? soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
VEXERCACAP5SJAVAlEX12 A.java e \EXERC\CAP5\JAVA\EX12_A.class 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
VEXERCACAP5JAVANEX12 B.java e \EXERC\CAP5\JAVA\EX12_B.class 


EEA Foi feita uma pesquisa para determinar o índice de mortalidade infantil em certo período. Faça um 
programa que: 


leia o número de crianças nascidas no período; 
identifique o sexo (M ou F) e o tempo de vida de cada criança nascida. 


O programa deve calcular e mostrar: 
a percentagem de crianças do sexo feminino mortas no período; 
a percentagem de crianças do sexo masculino mortas no período; 


a percentagem de crianças que viveram 24 meses ou menos no período. 
(AILIGIOJRILITIMIO) SoLução: 


ALGORITMO 

DECLARE i, num cri, meses, porc £f, porc m, tot f NUMÉRICO 
tot m, tot 24, porc 24 NUMÉRICO 
sexo LITERAL 

ESCREVA “Digite o número de crianças nascidas no período “” 

LEIA num cri 

totm < 0 

iene de e (9) 

tot 24 — 0 

PARA i — 1 ATE num cri FAÇA 
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INÍCIO 
ESCREVA “Digite o sexo da “, i, “è criança” 
LEIA sexo 
ESCREVA “Digite o tempo de vida (em meses) da “,i, “º criança” 
LEIA meses 
SE sexo = “M” 
ENTÃO tot m + tot m + 1 
SE sexo = “F” 
ENTÃO tot f — tot f + 1 
SE meses <= 24 
ENTÃO tot 24 — tot 24 + 1 
FIM 
SE num cri = 0 
ENTÃO ESCREVA “NENHUMA CRIANÇA DIGITADA” 
SENÃO INÍCIO 
porc_m — tot m * 100 / num cri 
porc f — tot £ * 100 / num cri 
porc 24 — tot 24 * 100 / num cri 
ESCREVA “Percentual de crianças do sexo feminino mortas ”, porc f 
ESCREVA “Percentual de crianças do sexo masculino mortas ”, porc m 
ESCREVA “Percentual de crianças com 24 meses ou menos mortas 
= no período ”, porc 24 
FIM 
FIM ALGORITMO. 


INSA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\PASCAL\EX13_A.PAS e \EXERC\CAP5\PASCAL\EX13_A. EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\PASCAL\EX13_B.PAS e \EXERC\CAP5\PASCAL\EX13_B.EXE 


LETA 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
D \EXERC\CAP5\C++\EX13_A.CPP e \EXERC\CAP5\C++\EX13_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX13_B.CPP e \EXERC\CAP5\C++\EX13_B.EXE 


BAIANO 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ed) NEXERCNCAPS NJAVANEX13 A.java e \EXERC\CAP5\JAVA\EX13_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\JAVA\EX13_B.java e NEXERCICAP5SJAVANEX13 B.class 


ELA Faça um programa que receba o valor de uma dívida e mostre uma tabela com os seguintes dados: 
valor da dívida, valor dos juros, quantidade de parcelas e valor da parcela. 


Os juros e a quantidade de parcelas seguem a tabela: 


QUANTIDADE DE PARCELAS % DE JUROS SOBRE O VALOR INICIAL DA DÍVIDA 
1 0 
3 10 
6 15 
9 20 
25 


N 
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Exemplo de saída do programa: 


VALOR DA VALOR DOS QUANTIDADE VALOR DA 
DIVIDA JUROS DE PARCELAS PARCELA 

R$ 1.000,00 0 1 R$ 1.000,00 

R$ 1.100,00 100 3 R$ 366,67 

R$ 1.150,00 150 6 R$ 191,67 


(AJLIGIOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE valor inicial, juros, valor parc NUMÉRICO 
total, valor juros, num parc, i NUMÉRICO 
ESCREVA “Digite o valor inicial da dívida” 
LEIA valor inicial 
juros — 0 
num parc — 1 
total — valor inicial 
valor parc + valor inicial 
ESCREVA total 
ESCREVA juros 
ESCREVA num parc 
ESCREVA valor parc 
juros — juros + 10 
num parc + num parc + 2 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
valor juros + valor inicial * juros / 100 
total — valor inicial + valor juros 
valor parc — total / num parc 
ESCREVA total 
ESCREVA valor juros 
ESCREVA num parc 
ESCREVA valor parc 
juros — juros + 5 
num parc — num parc + 3 
FIM 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
ed) NEXERCNCAPS VPASCALVEX14 A.PAS e NEXERCICAP5SAPASCALNEX14 A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\PASCAL\EX14_B.PAS e NEXERCICAP5SPASCALNEX14 B.EXE 


VLE RM 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
EE \EXERC\CAP5\C++\EX14_A.CPP e \EXERC\CAP5\C++\EX14_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX14_B.CPP e \EXERC\CAP5\C++\EX14_B.EXE 


VEGA 1? soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
\EXERC\CAP5\JAVA\EX14_A.java e NEXERCICAP5SJAVANEX14 A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 


\EXERC\CAP5\JAVA\EX14_B.java e \EXERC\CAP5\JAVA\EX14_B.class 
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EA Faça um programa que receba o preço unitário, a refrigeração (S para os produtos que necessitem de 
refrigeração e N para os que não necessitem) e a categoria (A — alimentação; L — limpeza; e V — 
vestuário) de doze produtos, e que calcule e mostre: 


O custo de estocagem, calculado de acordo com a tabela a seguir. 


PREÇO UNITÁRIO REFRIGERAÇÃO CATEGORIA CUSTO DE ESTOCAGEM 
A R$ 2,00 
Até 20 L R$ 3,00 
V R$ 4,00 
À ; S R$ 6,00 
Entre 20 e 50 (inclusive) 
N R$ 0,00 
A R$ 5,00 
S L R$ 2,00 
Maior que 50 V R$ 4,00 
AouV R$ 0,00 
À R$ 1,00 


O imposto calculado de acordo com as regras a seguir: 
Se o produto não preencher nenhum dos requisitos a seguir, seu imposto será de 2% sobre o preço 
unitário; caso contrário, será de 4%. 
Os requisitos são: categoria — A e refrigeração — S. 
O preço final, ou seja, preço unitário mais custo de estocagem mais imposto. 


A classificação calculada usando a tabela a seguir. 


PREÇO FINAL CLASSIFICAÇÃO 
Até R$ 20,00 Barato 
Entre R$ 20,00 e R$ 100,00 (inclusive) Normal 
Acima de R$ 100,00 Caro 


A média dos valores adicionais, ou seja, a média dos custos de estocagem e dos impostos dos doze 
produtos. 


O maior preço final. 

O menor preço final. 

O total dos impostos. 

A quantidade de produtos com classificação barato. 
A quantidade de produtos com classificação caro. 

A quantidade de produtos com classificação normal. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE i, preco, custo est, imp, preco final, adicional NUMÉRICO 
maior p, menor p, tot imp, qtd b, qgtd n, gtd c NUMÉRICO 
refri, categ LITERAL 

adicional — 0 

tot imp — 0 

qtd b — 0 

qtd_n — 0 

qtdc — 0 

PARA i — 1 ATÉ 12 FAÇA 

INÍCIO 
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LEIA preco 
LEIA refri 
LEIA categ 
SE preco <= 20 
ENTÃO INÍCIO 
SE categ = “A” 
ENTÃO custo est + 2 
SE categ = “L” 
ENTÃO custo est — 3 
SE categ = “V” 
ENTÃO custo est — 4 
FIM 
SE preco > 20 E preco <= 50 
ENTÃO INÍCIO 
Sm meti = “94 
ENTÃO custo est + 6 
SENÃO custo est — 0 
FIM 
SE preco > 50 
ENTÃO INÍCIO 


SElrefra Dus 
ENTÃO INÍCIO 
SE categ = “A” 
ENTÃO custo est + 5 
SE categ = “L” 
ENTÃO custo_est + 2 
SE categ = “V” 
ENTÃO custo_est + 4 
FIM 
SENÃO INÍCIO 
SE categ = “A” OU categ = “V” 
ENTÃO custo est — 0 
SE categ = “L” 
ENTÃO custo est — 1 
FIM 
FIM 


SE categ = “A” E refri = “S” 
ENTÃO imp — preco * 2 / 100 
SENÃO imp — preco * 4 / 100 
preco final « preco + custo est + imp 
ESCREVA custo est 
ESCREVA imp 
ESCREVA preco final 
SE preco final <= 20 
ENTÃO INÍCIO 
qtdb — qtd_b + 1 
ESCREVA “Classificação Barato” 
FIM 
SE preco final > 20 E preco final <= 100 
ENTÃO INÍCIO 
(anel sm <= crecl far dl 
ESCREVA “Classificação Normal” 
FIM 
SE preco final > 100 
ENTÃO INÍCIO 
qtdc + qgqtdc+1 
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ESCREVA “Classificação Caro” 
FIM 
adicional + adicional + custo est + imp 
tot imp — tot imp — imp 
SE i=1 
ENTÃO INÍCIO 
maior p — preco final 
menor p — preco final 
FIM 
SENÃO INÍCIO 
SE preco final > maior p 
ENTÃO maior p — preco final 
SE preco final < menor p 
ENTÃO menor p + preco final 
FIM 
FIM 
adicional — adicional / 12 
ESCREVA adicional 
ESCREVA maior p 
ESCREVA menor p 
ESCREVA tot imp 
ESCREVA qgtd b 
ESCREVA gtd n 
ESCREVA qtd c 
FIM ALGORITMO. 


INSA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
e) NEXERCNCAPS VPASCALXEX15 A.PAS e \EXERC\CAP5\PASCAL\EX15_A. EXE 


2º SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX15_B.PAS e NEXERCICAP5SPASCALNEX15 B.EXE 


[ePAeRNS 1º soLuçÃo — UTILIZANDO A ESTRUTURA FOR: 
D \EXERC\CAP5\C++\EX15_A.CPP e \EXERC\CAP5\C++\EX15_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\C++\EX15_B.CPP e \EXERC\CAP5\C++\EX15_B.EXE 
BAGA 12 SoLUÇÃO — UTILIZANDO A ESTRUTURA FOR: 
CED \EXERC\CAP5\JAVA\EX15_A.java e \EXERC\CAP5\JAVA\EX15_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX15_B.java e \EXERC\CAP5\JAVA\EX15_B.class 


HA Faça um programa para calcular a área de um triângulo e que não permita a entrada de dados inváli- 
dos, ou seja, medidas menores ou iguais a 0. 


(ALLISIOJEL ITIMO) Solução: 


ALGORITMO 
DECLARE base, altura, área NUMÉRICO 
REPITA 
LEIA base 
ATÉ base > 0 
REPITA 


LEIA altura 
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ATÉ altura > 0 

area — base * altura / 2 
ESCREVA area 

FIM ALGORITMO. 


INSTA A 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
VEXERCICAP5SPASCALNEX16 A.PAS e \EXERC\CAP5\PASCAL\EX16_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX16_B.PAS e NEXERCICAP5SPASCALNEX16 B.EXE 


Lee TSA 12 soLução — UTILIZANDO A ESTRUTURA WHILE: 
ed) VEXERCNCAPS \C++\EX16_A.CPP e \EXERC\CAP5\C++\EX16_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX16_B.CPP e \EXERC\CAP5\C++\EX16_B.EXE 


BAIANO 1? SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
med) \EXERC\CAP5\JAVA\EX1 6 A.java e NEXERCICAP5SIJAVANEX16 A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX16_B.java e NEXERCICAP5SJAVANEX16 B.class 


EFA Faça um programa que receba o salário de um funcionário chamado Carlos. Sabe-se que outro fun- 
cionário, João, tem salário equivalente a um terço do salário de Carlos. Carlos aplicará seu salário 
integralmente na caderneta de poupança, que rende 2% ao mês, e João aplicará seu salário inte- 
gralmente no fundo de renda fixa, que rende 5% ao mês. O programa deverá calcular e mostrar a 
quantidade de meses necessários para que o valor pertencente a João iguale ou ultrapasse o valor 
pertencente a Carlos. 


(AILISIOTRN ITIMO) Sorução: 


ALGORITMO 

DECLARE sal carlos, sal joao, meses NUMÉRICO 
LEIA sal carlos 

sal joao — sal carlos / 3 

meses <— 0 

ENQUANTO sal joao < sal carlos FAÇA 


INÍCIO 
sal carlos <— sal carlos + (sal carlos * 2 / 100) 
sal joao — sal joao + (sal joao * 5 / 100) 
meses — meses + 1 

FIM 


ESCREVA meses 
FIM ALGORITMO. 


INNA 1? SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\PASCAL\EX17_A.PAS e VEXERCACAP5SAPASCALNEX17 A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX17_B.PAS e NEXERCICAP5SPASCALNEX17 B.EXE 


PLoS 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) \EXERC\CAP5\C++\EX17_A.CPP e \EXERC\CAP5\C++\EX17_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX17_B.CPP e \EXERC\CAP5\C++\EX17_B.EXE 


136 | Fundamentos da programação de computadores 


BAIA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
(m) NEXERCNCAPSNJAVANEX1 7 A.java e NEXERCICAP5SIJAVANEX17 A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE.: 


NEXERCACAP5SAJAVANEX17 B.java e NEXERCACAPSIJAVANEX17 B.class 


EEJ Faça um programa que leia um conjunto não determinado de valores e mostre o valor lido, seu quadra- 
do, seu cubo e sua raiz quadrada. Finalize a entrada de dados com um valor negativo ou zero. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 

DECLARE num, quad, cubo, raiz NUMÉRICO 
LEIA num 

ENQUANTO num > 0 FAÇA 
INÍCIO 

quad + num * num 

cubo + num * num * num 
raiz — vnum 

ESCREVA quad, cubo, raiz 
LEIA num 

FIM 

FIM ALGORITMO. 


INSANA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
ea) NEXERCNCAPS VPASCALVEX18 A.PAS e NEXERCICAP5SYPASCALNEX18 A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 


\EXERC\CAP5\PASCAL\EX18_B.PAS e NEXERCICAP5SPASCALNEX18 B.EXE 


Lee TEA 1? soLução — UTILIZANDO A ESTRUTURA WHILE: 
Gia \EXERC\CAP5\C++\EX18_A.CPP e \EXERC\CAP5\C++\EX18_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX18_B.CPP e \EXERC\CAP5\C++\EX18_B.EXE 


E-G 1? soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
ed) \EXERC\CAP5\JAVA\EX1 8_A.java e \EXERC\CAP5\JAVA\EX18_A.class 


2º SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX18_B.java e \EXERC\CAP5\JAVA\EX18_B.class 


EL] Faça um programa que leia um número não determinado de pares de valores [m,n], todos inteiros e 
positivos, um par de cada vez, e que calcule e mostre a soma de todos os números inteiros entrem en 
(inclusive). A digitação de pares terminará quando m for maior ou igual a n. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE m, n, soma, i NUMÉRICO 
LEIA m 
LEIA n 
ENQUANTO m < n FAÇA 
INÍCIO 
soma — 0 
PARA i m ATÉ n FAÇA 
INÍCIO 
soma <— soma + i 
FIM 
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ESCREVA soma 
LEIA m 
LEIA n 

FIM 

FIM ALGORITMO. 


INNA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
ed) NEXERCNCAPS VPASCALXEX19 A.PAS e NEXERCICAP5SAPASCALNEX19 A.EXE 


2º SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
\EXERC\CAP5\PASCAL\EX19_B.PAS e NEXERCICAP5SPASCALNEX19 B.EXE 


PLE RM 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
D \EXERC\CAP5\C++\EX19_A.CPP e \EXERC\CAP5\C++\EX19_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\C++\EX19_B.CPP e \EXERC\CAP5\C++\EX19_B.EXE 


PEGA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
D \EXERC\CAP5\JAVA\EX19_A.java e \EXERC\CAP5\JAVA\EX19_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX19_B.java e \EXERC\CAP5\JAVA\EX19_B.class 


EXA Faça um programa para ler o código, o sexo (M — masculino; F — feminino) e o número de horas/ 
aula dadas mensalmente pelos professores de uma universidade, sabendo-se que cada hora/aula vale 
R$ 30,00. Emita uma listagem contendo o código, o salário bruto e o salário líquido (levando em 
consideração os descontos explicados a seguir) de todos os professores. Mostre também a média dos 
salários líquidos dos professores do sexo masculino e a média dos salários líquidos dos professores do 
sexo feminino. Considere: 


desconto para homens, 10%, e, para mulheres, 5%; 
as informações terminarão quando for lido o código = 99999. 


(AILTSIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE cod, num h, sal b, sal l, media m, media f NUMÉRICO 
cont m, cont f NUMÉRICO 
sexo LITERAL 
LEIA cod 
cont m + 0 
cont f = 0 
ENQUANTO cod * 99999 FAÇA 
INÍCIO 
LEIA sexo 
LEIA num h 
sal b <— num h * 30 
SE sexo = "M" 
ENTÃO INÍCIO 
sal 1 — sal b- (sal b* 10 / 100) 
media m — media m+ sal 1 
cont m + cont m + 1 
FIM 
SE sexo = "F" 
ENTÃO INÍCIO 
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FIM 
ESCREVA cod 


BeuL dl 


cont dr «— 


ESCREVA sal b 


ESCREVA sal 


LEIA cod 
FIM 
SE cont m = 0 


1l 


sal_b — (sal b * 5 / 100) 
media_f — media_f + sal 1 
Contare 


ENTÃO ESCREVA "Nenhum professor do sexo masculino" 


SENÃO INÍCIO 


media m — media_m / cont m 
ESCREVA media m 


FIM 
SE cont f = 0 


ENTÃO ESCREVA "Nenhum professor do sexo feminino” 


SENÃO INÍCIO 


media f — media f / cont £ 
ESCREVA media f 


FIM 
FIM ALGORITMO. 


PASCAL 14 SOLUÇÃO — UT 
C \EXERC\CAP5 


22 SOLUÇÃO — UT 


\EXERC\CAP5 


PLoS TT 1º soLução — UT 
n \EXERC\CAP5 


22 SOLUÇÃO — UT 


\EXERC\CAP5 


REGIS 12 soLUÇÃO — UT 
D \EXERC\CAP5 


22 SOLUÇÃO — UT 


LIZAN 
\PAS 
LIZAN 
\PAS 


LIZAN 


LIZAN 


ZAN 


\JAVA\EX20 


ZAN 


DO A ESTR 


DO A ESTR 


DO A ESTR 


DO A ESTR 


\C++\EX20_B. 


DO A ESTR 


DO A ESTR 


UT! 


CALNEX20 


UT! 


CALNEX20 


UT! 


\C++\EX20 A. 


UT! 


UT! 


A 


UT! 


RA WHILE: 
A.PAS e \EXERC\CAP5\PASCAL\EX20_A. EXE 
Ra REPEAT: 


_B.PAS e \EXERC\CAP5\PASCAL\EX20_B.EXE 


RA WHILE: 


CPP e \EXERC\CAP5\C++\EX20_A.EXE 


Ra DO-WHILE: 


CPP e \EXERC\CAP5\C++\EX20_B.EXE 


RA WHILE: 


.java e \EXERC\CAP5\JAVA\EX20_A.class 


Ra DO-WHILE: 


\EXERC\CAP5\JAVA\EX20_B.java e \EXERC\CAP5\JAVA\EX20_B.class 


PR Faça um programa que receba vários números, calcule e mostre: 


a soma dos números digitados; 


a quantidade de números digitados; 


a média dos números digitados; 


o maior número digitado; 


o menor número digitado; 


a média dos números pares; 


a porcentagem dos números ímpares entre todos os números digitados. 


Finalize a entrada de dados com a digitação do número 30.000. 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE num, soma, qtd, maior, menor, qgtd par NUMÉRICO 
media par, soma par, qgtd impar, media, perc NUMÉRICO 
qtd — 0 
qtd_par + 0 
soma par + 0 
qtd_impar — 0 
soma <— 0 
LEIA num 
ENQUANTO num * 30000 FAÇA 
INÍCIO 
SE qtd = 0 
ENTÃO INÍCIO 
maior — num 
menor +— num 
FIM 
SENÃO INÍCIO 
SE num > maior 
ENTÃO maior — num 
SE num < menor 
ENTÃO menor — num 
FIM 
soma < soma + num 
qtd — qtd + 1 
SE RESTO (num/2) = 0 
ENTÃO INÍCIO 
soma par — soma par + num 
gtd par + atd par + 1 
FIM 
SENÃO qgtd impar + qtd impar + 1 
LEIA num 
FIM 
SE qtd = 0 
ENTÃO ESCREVA “Nenhum número digitado” 
SENÃO INÍCIO 
ESCREVA soma 
ESCREVA qtd 
media — soma / qtd 
ESCREVA media 
ESCREVA maior 
ESCREVA menor 
SE qtd par = 0 
ENTÃO ESCREVA “nenhum par” 
SENÃO INÍCIO 
media par < soma par / qtd par 
ESCREVA media par 
FIM 
perc — qtd impar * 100 / qtd 
ESCREVA perc 
FIM 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) \EXERC\CAP5\PASCAL\EX2 1 A.PAS e \EXERC\CAP5\PASCAL\EX21_A. EXE 
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22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 


VEXERCICAP5SAPASCALNEX21 B.PAS e VEXERCACAP5SAPASCALNEX21 B.EXE 
VLE TSA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\C++\EX21_A.CPP e \EXERC\CAP5\C++\EX21_A.EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\C++\EX21_B.CPP e \EXERC\CAP5\C++\EX21_B.EXE 
AEGAN 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) \EXERC\CAP5\JAVA\EX2 1 A.java e \EXERC\CAP5\JAVA\EX21_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX21_B.java e NEXERCICAP5SJAVANEX21 B.class 


EFA Uma empresa decidiu fazer um levantamento em relação aos candidatos que se apresentarem para 
preenchimento de vagas em seu quadro de funcionários. Supondo que você seja o programador dessa 
empresa, faça um programa que leia, para cada candidato, a idade, o sexo (M ou F) e a experiência no 
serviço (S ou N). Para encerrar a entrada de dados, digite zero para a idade. 


O programa também deve calcular e mostrar: 
o número de candidatos do sexo feminino; 
o número de candidatos do sexo masculino; 
a idade média dos homens que já têm experiência no serviço; 
a porcentagem dos homens com mais de 45 anos entre o total dos homens; 
o número de mulheres com idade inferior a 21 anos e com experiência no serviço; 


a menor idade entre as mulheres que já têm experiência no serviço. 
(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 

DECLARE idade, tot f, tot m, somal, cont ml, cont m2, tot NUMÉRICO 
cont fl, media idade, perc, menor idade NUMÉRICO 
sexo, exp LITERAL 

tot — 0 

oie ae = W) 

totm < 0 

somal <— 0 

cont mi = 0 

cont m2 + 0 

cont fl — 0 


LEIA idade 
ENQUANTO idade * 0 FAÇA 
INÍCIO 
LEIA sexo 
LEIA exp 
SE sexo = “F” E exp = “5” 
ENTÃO INÍCIO 


SE tot = 0 
ENTÃO INÍCIO 
menor idade <— idade 
ope — À 
FIM 
SENÃO SE idade < menor idade 
ENTÃO menor idade — idade 
FIM 
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SE sexo = “M” 
ENTÃO tot m — totm+1 
SE sexo = “F” 
ENTÃO tot_f — tot f +1 
SE sexo = “F” E idade < 21 E exp = “S” 
ENTÃO cont fl — cont f1 + 1 
SE sexo = “M” E idade > 45 
ENTÃO cont ml — cont ml + 1 
SE sexo = “M” E exp = “5” 


ENTÃO INÍCIO 
somal — somal + idade 
cont m2 + cont m2 + 1 
FIM 
LEIA idade 
FIM 
ESCREVA tot f 
ESCREVA tot m 
SE cont m2 = 0 
ENTÃO ESCREVA “Nenhum homem com experiência" 
SENÃO INÍCIO 
media idade — somal / cont m2 
ESCREVA media idade 
FIM 
SE tot m = 0 
ENTÃO ESCREVA “Nenhum homem” 
SENÃO INÍCIO 
perc — cont ml * 100 / tot m 
ESCREVA perc 
FIM 
ESCREVA cont f1 
ESCREVA menor idade 
FIM ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
\EXERC\CAP5\PASCAL\EX22_A.PAS e \EXERC\CAP5\PASCAL\EX22_A. EXE 
22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
VEXERCICAP5SPASCALNEX22 B.PAS e NEXERCICAP5SPASCALVEX22 B.EXE 


Ple RM 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
D \EXERC\CAP5\C++\EX22_A.CPP e \EXERC\CAP5\C++\EX22_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX22_B.CPP e \EXERC\CAP5\C++\EX22_B.EXE 


BAIA 1? soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
D \EXERC\CAP5\JAVA\EX22_A.java e \EXERC\CAP5\JAVA\EX22_A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


\EXERC\CAP5\JAVA\EX22_B.java e \EXERC\CAP5\JAVA\EX22_B.class 


PER Faça um programa que receba o valor do salário mínimo, uma lista contendo a quantidade de quilo- 
watts gasta por consumidor e o tipo de consumidor (1 — residencial; 2 — comercial; ou 3 — indus- 
trial) e que calcule e mostre: 

o valor de cada quilowatt, sabendo que o quilowatt custa um oitavo do salário mínimo; 
o valor a ser pago por consumidor (conta final mais acréscimo). O acréscimo encontra-se na tabela 
a seguir: 
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% DE ACRÉSCIMO SOBRE O 
VALOR GASTO 


1 5 
10 
15 


TIPO 


o faturamento geral da empresa; 
a quantidade de consumidores que pagam entre R$ 500,00 e R$ 1.000,00. 
Termine a entrada de dados com quantidade de quilowats igual a zero. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 

DECLARE sal, qtd, tipo, valor kw, gasto, acresc NUMÉRICO 
total, tot geral, qtd cons NUMÉRICO 

tot geral < 0 

gtd cons + 0 

LEIA sal, qtd 

valor kw — sal / 8 

ENQUANTO qtd * 0 FAÇA 


INÍCIO 
gasto + qtd * valor kw 
LEIA tipo 


SE tipo = 1 
ENTÃO acresc + gasto * 5 / 100 
SE tipo = 2 
ENTÃO acresc — gasto * 10 / 100 
SE tipo = 3 
ENTÃO acresc — gasto * 15 / 100 
total <— gasto + acresc 
tot geral — tot geral + total 
SE total >= 500 E total <= 1000 
ENTÃO gtd cons + gtd cons + 1 
ESCREVA gasto 
ESCREVA acresc 
ESCREVA total 
LEIA qtd 
FIM 
ESCREVA tot geral 
ESCREVA qgtd cons 
FIM ALGORITMO. 


ij Ne{0 NA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
ed) NEXERCNCAPS VPASCALVEX23 A.PAS e NEXERCICAP5APASCALNEX23 A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 
VEXERCICAP5SPASCALNEX23 B.PAS e NEXERCICAP5SPASCALNEX23 B.EXE 


LETT 12 soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) VEXERCNCAP5SNC++NEX23 A.CPP e \EXERC\CAP5\C++\EX23_A.EXE 


2º SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 
\EXERC\CAP5\C++\EX23_B.CPP e \EXERC\CAP5\C++\EX23_B.EXE 
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BAIA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
e) \EXERC\CAP5\JAVA\EX2 3 A.java e NEXERCICAP5SJAVANEX23 A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE.: 


NEXERCACAPSAJAVANEX23 B.java e NEXERCICAPSIJAVANEX23 B.class 


EZY Faça um programa que apresente o menu de opções a seguir, permita ao usuário escolher a opção 
desejada, receba os dados necessários para executar a operação e mostre o resultado. Verifique a pos- 
sibilidade de opção inválida e não se preocupe com restrições do tipo salário inválido. 


Menu de opções: 

1. Imposto 

2. Novo salário 

3. Classificação 

4. Finalizar o programa 
Digite a opção desejada. 


Na opção 1: receber o salário de um funcionário, calcular e mostrar o valor do imposto usando as regras 
a seguir. 


SALÁRIOS % DO IMPOSTO 
Menor que R$ 500,00 5 
De R$ 500,00 a R$ 850,00 10 
Acima de R$ 850,00 15 


Na opção 2: receber o salário de um funcionário, calcular e mostrar o valor do novo salário usando as 
regras a seguir. 


SALÁRIOS AUMENTO 
Maiores que R$ 1.500,00 R$ 25,00 
De R$ 750,00 (inclusive) a R$ 1.500,00 (inclusive) R$ 50,00 
De R$ 450,00 (inclusive) a R$ 750,00 R$ 75,00 
Menores que R$ 450,00 R$ 100,00 


Na opção 3: receber o salário de um funcionário e mostrar sua classificação usando esta tabela: 


SALÁRIOS CLASSIFICAÇÃO 
Até R$ 700,00 Mal remunerado 
Maiores que R$ 700,00 Bem remunerado 
ELIRO) Solução: 
ALGORITMO 
DECLARE op, sal, imp, aum, novo sal NUMÉRICO 
REPITA 


ESCREVA " MENU DE OPÇÕES" 
ESCREVA “1- Imposto” 

ESCREVA “2- Novo Salário” 
ESCREVA “3- Classificação” 
ESCREVA “4- Finalizar o programa” 
ESCREVA “Digite a opção desejada” 
LEIA op 

SE op > 4 OU op < 1 

ENTÃO ESCREVA “Opção inválida !” 
SE op = 1 
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ENTÃO INÍCIO 
LEIA sal 
SE sal < 500 


ENTÃO imp — sal * 5/100 
SE sal >= 500 E sal <= 850 
ENTÃO imp — sal * 10/100 


SE sal > 850 


ENTÃO imp — sal * 15/100 


ESCREVA imp 


FIM 

SE op = 2 

ENTÃO INÍCIO 
LEIA sal 


SE sal > 1500 
ENTÃO aum — 25 


SE sal >= 750 E sal <= 1500 


ENTÃO aum — 50 


SE sal >= 450 E sal < 750 


ENTÃO aum — 75 
SE sal < 450 


ENTÃO aum — 100 


novo sal + sal 
ESCREVA novo sa 
FIM 

SE op = 3 

ENTÃO INÍCIO 
LEIA sal 
SE sal <= 700 


+ aum 
1l 


ENTÃO ESCREVA “Mal Remunerado” 
SENÃO ESCREVA “Bem Remunerado” 


FIM 
ATÉ op = 4 
FIM ALGORITMO. 


JANSA 1º SOLUÇÃO — UTILIZAN 
\EXERC\CAP5\PAS 
22 SOLUÇÃO — UTILIZAN 
\EXERC\CAP5\PAS 


eVet TT 12 soLução — UTILIZAN 


22 SOLUÇÃO — UTILIZAN 


\EXERC\CAP5\C++\EX24_B. 


E-G 1º SOLUÇÃO — UTILIZAN 


\EXERC\CAP5\JAVA\EX24 


2º SOLUÇÃO — UTILIZAN 


DO A ESTR 


DO A ESTR 


DO A ESTR 


DO A ESTR 


DO A ESTR 


\EXERC\CAP5\C++\EX24_A. 


DO A ESTR 


UT! 


CALNEX24 


UT! 


CALNEX24 


UT! 


UT! 


UT! 


A 


UT! 


Ra REPEAT: 

A.PAS e \EXERC\CAP5\PASCAL\EX24_A. EXE 
Ra WHILE: 

B.PAS e \EXERC\CAP5\PASCAL\EX24_B. EXE 


Ra DO-WHILE: 


CPP e \EXERC\CAP5\C++\EX24_A.EXE 


RA WHILE: 


CPP e \EXERC\CAP5\C++\EX24 B.EXE 


Ra DO-WHILE: 


.java e \EXERC\CAP5\JAVA\EX24_A.class 


RA WHILE: 


\EXERC\CAP5\JAVA\EX24_B.java e \EXERC\CAP5\JAVA\EX24_B.class 


FER Faça um programa que receba os dados a seguir de vários produtos: preço unitário, país de origem 
(1 — Estados Unidos; 2 — México; e 3 — outros), meio de transporte (T — terrestre; F — fluvial; e À 
— aéreo), carga perigosa (S — sim; N — não), finalize a entrada de dados com um preço inválido, ou 
seja, menor ou igual a zero. O programa deve calcular e mostrar os itens a seguir. 
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O valor do imposto, usando a tabela a seguir. 


PERCENTUAL DE IMPOSTO 
SOBRE O PREÇO UNITÁRIO 


Até R$ 100,00 5% 
Maior que R$ 100,00 10% 


PREÇO UNITÁRIO 


O valor do transporte usando a tabela a seguir. 


CARGA PERIGOSA PAÍS DE ORIGEM VALOR DO TRANSPORTE 
R$ 50,00 
R$ 21,00 
R$ 24,00 
R$ 12,00 
R$ 21,00 
R$ 60,00 


WIN a NAN a 


O valor do seguro, usando a regra a seguir. 


Os produtos que vêm do México e os produtos que utilizam transporte aéreo pagam metade do valor 
do seu preço unitário como seguro. 


O preço final, ou seja, preço unitário mais imposto mais valor do transporte mais valor do seguro. 


O total dos impostos. 
(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE preco, imp, transp, seguro, final NUMÉRICO 
total imp, origem NUMÉRICO 
meio t, carga LITERAL 
LEIA preco 
ENQUANTO preco > 0 FAÇA 
INÍCIO 
LEIA origem 
LEIA meio t 
LEIA carga 
SE preco <= 100 
ENTÃO imp — preco * 5 / 100 
SENÃO imp — preco * 10 / 100 
SE carga = “5” 
ENTÃO INÍCIO 
SE origem = 1 
ENTÃO transp <— 50 
SE origem = 2 
ENTÃO transp + 21 
SE origem = 3 
ENTÃO transp + 24 
FIM 
SE carga = “N” 
ENTÃO INÍCIO 
SE origem = 1 
ENTÃO transp — 12 
SE origem = 2 
ENTÃO transp + 21 
SE origem = 3 
ENTÃO transp — 60 
FIM 
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SE origem = 2 OU meio t = “A” 
ENTÃO seguro + preco/2 
SENÃO seguro <— 0 
final — preco + imp + transp + seguro 
total imp — total imp + imp 
ESCREVA imp 
ESCREVA transp 
ESCREVA seguro 
ESCREVA final 
LEIA preco 
FIM 
ESCREVA total imp 
FIM ALGORITMO. 


ij Ne{0 N 1º SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
ed) NEXERCNCAPS VPASCALVEX25 A.PAS e \EXERC\CAP5\PASCAL\EX25_A. EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA REPEAT: 


\EXERC\CAP5\PASCAL\EX25_B.PAS e NEXERCICAP5SPASCALNEX25 B.EXE 


PLETA 12 soLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
(C) NEXERCNCAPS VC++VEX25 A.CPP e \EXERC\CAP5\C++\EX25_A.EXE 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE.: 


\EXERC\CAP5\C++\EX25_B.CPP e \EXERC\CAP5\C++\EX25_B.EXE 


RANMA 12 SOLUÇÃO — UTILIZANDO A ESTRUTURA WHILE: 
ed) \EXERC\CAP5\JAVA\EX2 5 A.java e NEXERCACAP5SJAVANEX25 A.class 


22 SOLUÇÃO — UTILIZANDO A ESTRUTURA DO-WHILE: 


NEXERCACAP5SAJAVANEX25 B.java e NEXERCACAPSIJAVANEX25 B.class 


EXERCÍCIOS PROPOSTOS 


BEER Faça um programa que leia cinco grupos de quatro valores (A, B, C, D) e mostre-os na ordem lida. Em segui- 
da, organize-os em ordem crescente e decrescente. 

IFA Uma companhia de teatro deseja montar uma série de espetáculos. A direção calcula que, a 
R$ 5,00 o ingresso, serão vendidos 120 ingressos, e que as despesas serão de R$ 200,00. Diminuindo-se em 
R$ 0,50 o preço dos ingressos, espera-se que as vendas aumentem em 26 ingressos. Faça um programa que 
escreva uma tabela de valores de lucros esperados em função do preço do ingresso, fazendo-se variar esse pre- 
ço de R$ 5,00 a R$ 1,00, de R$ 0,50 em R$ 0,50. Escreva, ainda, para cada novo preço de ingresso, o lucro 
máximo esperado, o preço do ingresso e a quantidade de ingressos vendidos para a obtenção desse lucro. 

IEJ Faça um programa que receba a idade de oito pessoas, calcule e mostre: 
a) a quantidade de pessoas em cada faixa etária; 
b) a porcentagem de pessoas na primeira faixa etária com relação ao total de pessoas. 
c) a porcentagem de pessoas na última faixa etária com relação ao total de pessoas 


FAIXA ETÁRIA IDADE 
P Até 15 anos 
22 De 16 a 30 anos 
3º De 31 a 45 anos 
42 De 46 a 60 anos 


5a Acima de 60 anos 
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IZA Faça um programa que receba um número, calcule e mostre a tabuada desse número. 


Exemplo: 
Digite um número: 5 
Sx0=0 
Sx1l=5 
Sx2=10 
SKISS 
5 x4=20 
5x5=25 
5 x6=30 
5x7=35 
5 x 8=40 
5 x9=45 
5 x 10=50 


EA Faça um programa que mostre as tabuadas dos números de 1 a 10. 


EA Uma loja utiliza o código V para transação à vista e P para transação a prazo. Faça um programa que receba 
o código e o valor de quinze transações, calcule e mostre: 


o valor total das compras à vista; 

o valor total das compras a prazo; 

o valor total das compras efetuadas; e 

o valor da primeira prestação das compras a prazo juntas, sabendo-se que serão pagas em três vezes. 
IEA Faça um programa que receba a idade, a altura e o peso de cinco pessoas, calcule e mostre: 

a quantidade de pessoas com idade superior a 50 anos; 

a média das alturas das pessoas com idade entre 10 e 20 anos; 

a porcentagem de pessoas com peso inferior a 40 kg entre todas as pessoas analisadas. 


REA Faça um programa que receba a idade, o peso, a altura, a cor dos olhos (A — azul; P — preto; V — verde; e 
C — castanho) e a cor dos cabelos (P — preto; C — castanho; L — louro; e R — ruivo) de seis pessoas, e que 
calcule e mostre: 


a quantidade de pessoas com idade superior a 50 anos e peso inferior a 60 kg; 
a média das idades das pessoas com altura inferior a 1,50 m; 
a porcentagem de pessoas com olhos azuis entre todas as pessoas analisadas; e 
a quantidade de pessoas ruivas e que não possuem olhos azuis. 
BEAR Faça um programa que receba dez idades, pesos e alturas, calcule e mostre: 
a média das idades das dez pessoas; 
a quantidade de pessoas com peso superior a 90 kg e altura inferior a 1,50 metro; e 


a porcentagem de pessoas com idade entre 10 e 30 anos entre as pessoas que medem mais de 
1,90 m. 


ELA Faça um programa que receba dez números, calcule e mostre a soma dos números pares e a soma dos 
números primos. 


EEE Faça um programa que receba o valor de um carro e mostre uma tabela com os seguintes dados: preço 
final, quantidade de parcelas e valor da parcela. Considere o seguinte: 


o preço final para compra à vista tem desconto de 20%; 
a quantidade de parcelas pode ser: 6, 12, 18, 24, 30, 36, 42, 48, 54 e 60; e 


os percentuais de acréscimo encontram-se na tabela a seguir. 
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QUANTIDADE PERCENTUAL DE ACRÉSCIMO 
DE PARCELAS SOBRE O PREÇO FINAL 

6 3% 

2 6% 

18 9% 

24 12% 

30 15% 

36 18% 

42 21% 

48 24% 

54 27% 

60 30% 


EFA Faça um programa que receba dez números inteiros e mostre a quantidade de números primos dentre os 
números que foram digitados. 


EEA Faça um programa que receba a idade e o peso de quinze pessoas, e que calcule e mostre as médias dos 
pesos das pessoas da mesma faixa etária. As faixas etárias são: de 1 a 10 anos, de 11 a 20 anos, de 21 a 
30 anos e de 31 anos para cima. 


ELA Cada espectador de um cinema respondeu a um questionário no qual constava sua idade e sua opinião 
em relação ao filme: ótimo — 3; bom — 2; regular — 1. Faça um programa que receba a idade e a opi- 
nião de quinze espectadores, calcule e mostre: 


a média das idades das pessoas que responderam ótimo; 
a quantidade de pessoas que responderam regular; e 
a percentagem de pessoas que responderam bom, entre todos os espectadores analisados. 


HA Uma empresa fez uma pesquisa de mercado para saber se as pessoas gostaram ou não de um novo pro- 
duto lançado. Para isso, forneceu o sexo do entrevistado e sua resposta (S — sim; ou N — não). Sabe-se 
que foram entrevistadas dez pessoas. Faça um programa que calcule e mostre: 


o número de pessoas que responderam sim; 

o número de pessoas que responderam não; 

o número de mulheres que responderam sim; e 

a percentagem de homens que responderam não, entre todos os homens analisados. 


ELA Faça um programa que receba várias idades, calcule e mostre a média das idades digitadas. Finalize di- 
gitando idade igual a zero. 


ERA Foi feita uma pesquisa sobre a audiência de canal de TV em várias casas de uma cidade, em determinado 
dia. Para cada casa consultada foi fornecido o número do canal (4, 5, 7, 12) e o número de pessoas que 
estavam assistindo àquele canal. Se a televisão estivesse desligada, nada era anotado, ou seja, essa casa 
não entrava na pesquisa. Faça um programa que: 


leia um número indeterminado de dados (número do canal e número de pessoas que estavam as- 
sistindo); e 
calcule e mostre a porcentagem de audiência de cada canal. 

Para encerrar a entrada de dados, digite o número do canal ZERO. 


ETJ Foi feita uma pesquisa entre os habitantes de uma região. Foram coletados os dados de idade, sexo (M/F) 
e salário. Faça um programa que calcule e mostre: 


a média dos salários do grupo; 

a maior e a menor idade do grupo; 

a quantidade de mulheres com salário até R$ 200,00; 
a idade e o sexo da pessoa que possui o menor salário. 


Finalize a entrada de dados ao ser digitada uma idade negativa. 
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EL] Faça um programa que receba o tipo da ação, ou seja, uma letra a ser comercializada na bolsa de valores, 
o preço de compra e o preço de venda de cada ação e que calcule e mostre: 


o lucro de cada ação comercializada; 
a quantidade de ações com lucro superior a R$ 1.000,00; 
a quantidade de ações com lucro inferior a R$ 200,00; 
o lucro total da empresa. 
Finalize com o tipo de ação ‘P’. 
EXA Faça um programa que apresente o menu de opções a seguir: 


Menu de opções: 

1. Média aritmética 
2. Média ponderada 
3. Sair 


Digite a opção desejada. 
Na opção 1: receber duas notas, calcular e mostrar a média aritmética. 
Na opção 2: receber três notas e seus respectivos pesos, calcular e mostrar a média ponderada. 
Na opção 3: sair do programa. 
Verifique a possibilidade de opção inválida. Nesse caso, o programa deverá mostrar uma mensagem. 


PIE Em uma eleição presidencial existem quatro candidatos. Os votos são informados por meio de código. 
Os códigos utilizados são: 


1,2,3,4 Votos para os respectivos candidatos 
5 Voto nulo 
6 Voto em branco 


Faça um programa que calcule e mostre: 
o total de votos para cada candidato; 
o total de votos nulos; 
o total de votos em branco; 
a porcentagem de votos nulos sobre o total de votos; e 
a porcentagem de votos em branco sobre o total de votos. 


Para finalizar o conjunto de votos, tem-se o valor zero e, para códigos inválidos, o programa deverá 
mostrar uma mensagem. 


EFA Faça um programa que receba a idade e a altura de várias pessoas, calcule e mostre a média das alturas 
daquelas com mais de 50 anos. Para encerrar a entrada de dados, digite idade menor ou igual a zero. 


PFJ Faça um programa que apresente o menu de opções a seguir, que permita ao usuário escolher a opção 
desejada, receba os dados necessários para executar a operação e mostre o resultado. Verifique a possibi- 
lidade de opção inválida e não se preocupe com as restrições como salário inválido. 


Menu de opções: 
1. Novo salário 

2. Férias 

3. Décimo terceiro 
4. Sair 


Digite a opção desejada. 


Na opção 1: receber o salário de um funcionário, calcular e mostrar o novo salário usando as regras a se- 
guir: 
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SALÁRIOS PERCENTAGEM DE AUMENTO 
Até R$ 210,00 15% 
De R$ 210,00 a R$ 600,00 (inclusive) 10% 
Acima de R$ 600,00 5% 


Na opção 2: receber o salário de um funcionário, calcular e mostrar o valor de suas férias. Sabe-se que as 
férias equivalem a seu salário acrescido de um terço do salário. 


Na opção 3: receber o salário de um funcionário e o número de meses de trabalho na empresa, no máximo 
doze, calcular e mostrar o valor do décimo terceiro. Sabe-se que o décimo terceiro equivale a seu salário 
multiplicado pelo número de meses de trabalho dividido por 12. 

Na opção 4: sair do programa. 


PZA Faça um programa que receba um conjunto de valores inteiros e positivos, calcule e mostre o maior e o 
menor valor do conjunto. Considere que: 


para encerrar a entrada de dados, deve ser digitado o valor zero; 
para valores negativos, deve ser enviada uma mensagem; 
os valores negativos ou iguais a zero não entrarão nos cálculos. 


FER Uma agência bancária possui vários clientes que podem fazer investimentos com rendimentos mensais, 
conforme a tabela a seguir: 


TIPO DESCRIÇÃO RENDIMENTO MENSAL 
1 Poupança 1,5% 
Poupança plus 2% 
Fundos de renda fixa 4% 


Faça um programa que leia o código do cliente, o tipo do investimento e o valor investido, e que calcule 
e mostre o rendimento mensal de acordo com o tipo do investimento. No final, o programa deverá mostrar 
o total investido e o total de juros pagos. 

A leitura terminará quando o código do cliente digitado for menor ou igual a 0. 


CAPÍTULO 


6.1 Vetor em algoritmos 


6.1.1 Definição de vetor 


Vetor também é conhecido como variável composta homogênea unidimensional. Isso quer dizer que 
se trata de um conjunto de variáveis de mesmo tipo, que possuem o mesmo identificador (nome) e são alo- 
cadas sequencialmente na memória. Como as variáveis têm o mesmo nome, o que as distingue é um índice 
que referencia sua localização dentro da estrutura. 


6.1.2 Declaração de vetor 


DECLARE nome [tamanho] tipo 


onde: 


nome é o nome da variável do tipo vetor; 
tamanho é a quantidade de variáveis que vão compor o vetor; 
tipo é o tipo básico dos dados que serão armazenados no vetor. 


6.1.3 Exemplos de vetor 


X[1] 


DECLARE X[5] NUMÉRICO 


Acima podemos observar a criação de um vetor chamado X, que possui cinco posições. Ou seja, foram 
alocadas cinco porções de memória para armazenamento de números. Essas porções de memória são con- 
tíguas, isto é, seus endereços são sequenciais. 


6.1.4 Atribuindo valores ao vetor 
Uma vez que todas as posições de um vetor possuem o mesmo nome, as atribuições exigem que seja 
informada em qual de suas posições o valor ficará armazenado. 
X[1] — 45 
X[4] — 0 
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No primeiro exemplo dado, o número 45 será armazenado na posição de índice 1 do vetor. Já no se- 
gundo exemplo, o número 0 será armazenado na posição de índice 4 do vetor. 


6.1.5 Preenchendo um vetor 


Preencher um vetor significa atribuir valores a todas as suas posições. Assim, deve-se implementar um 
mecanismo que faça uma variável assumir todos os valores possíveis para o índice. 


PARA i — 1 ATÉ 5 FAÇA 

INÍCIO 
ESCREVA "Digite o ", i, "° número" 
LEIA X[i] 

FIM 


Nesse exemplo, a estrutura de repetição PARA foi utilizada para garantir que a variável i assuma todos 
os valores possíveis entre 1 e 5 (posições válidas para o vetor X). Assim, para cada execução da repetição, 
será utilizada uma posição diferente do vetor. 


Simulação: 
MEMÓRIA TELA 
i=] X 95 Digite o 1º número 
2 3 4 5 95 
X 95 3 Digite o 2º número 
=2 
2 3 4 5 13 
X 95 3 | -25 Digite o 3º número 
=3 
2 3 4 5 -25 
X 95 3 |=25 | 47 Digite o 4º número 
=4 
E 3 4 5 au 
au X 95 3 | -25 | 47 O Digite o 5º número 
2 3 4 5 O 


6.1.6 Mostrando os elementos do vetor 


Mostrar os valores contidos em um vetor também implica na utilização do índice. 


PARA i < 1 ATÉ 5 FAÇA 

INÍCIO 
ESCREVA “Este é o “, i, “º número do vetor” 
ESCREVA X[i] 

FIM 


Nesse exemplo, a estrutura de repetição PARA também foi utilizada para garantir que a variável i assu- 
ma todos os valores possíveis para o índice do vetor. Com isso, a cada execução da repetição, um valor de 
posição diferente será mostrado. 


6.2 Vetor em PASCAL 


6.2.1 Definição de vetor 


As variáveis compostas homogêneas unidimensionais (vetores) são conhecidas na linguagem PASCAL 
como ARRAY. Todas as posições do ARRAY possuem o mesmo identificador (mesmo nome) e são alocadas 
sequencialmente na memória. 
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6.2.2 Declaração de vetor 


VAR nome da variável: ARRAY[índice inicial .. índice final] OF tipo dos dados do vetor; 


onde: 


nome da variável é o nome da variável do tipo vetor; 

índice inicial é o valor correspondente ao índice da primeira posição do vetor; 
índice final é o valor correspondente ao índice da última posição do vetor; 

tipo dos dados do vetor é o tipo básico dos dados que serão armazenados no vetor. 


E importante salientar que o valor do índice inicial deve ser maior ou igual ao valor do índice fi- 
nal. As posições são identificadas com valores dentro desse intervalo. 


Exemplo 1: 

VAR vetorl: ARRAY [1..10] OF INTEGER; 
Nesse caso, o índice poderá assumir valores inteiros que vão de 1 a 10. 
Exemplo 2: 

VAR vetorl: ARRAY [5..9] OF REAL; 


Nesse caso, o índice poderá assumir valores inteiros que vão de 5 a 9. 

Outro ponto importante a ser destacado é que os índices também podem ser representados por valores 
alfabéticos. Com isso, é permitido o uso de caracteres para representar o valor inicial eo valor final. 
Obviamente, a regra que obriga o valor final ser maior ou igual ao valor inicial continua valendo. O 
exemplo 3, a seguir, ilustra essa possibilidade. 


Exemplo 3: 
VAR vetorl: ARRAY ['C'..'G'] OF REAL; 


Nesse caso, o índice poderá assumir valores que vão de Ca G. 


QOQ Observação 


Os valores que indicam o índice inicial e o índice final devem representar valores fixos (lite- 
rais! ou constantes), não podendo ser substituídos por variáveis. 


6.2.3 Exemplos de vetor 


VAR X:ARRAY[1..10] OF REAL; 


X 10.5 20 13.1 14.65 87 1:2 35.6 78.2 15 65.9 
1 2 3 4 5 6 7 8 9 10 


VAR VET: ARRAY[5..9] OF CHAR; 


VET E t m J k 
6 7 8 
VAR X:ARRAY[ D'..'G'] OF INTEGER; 
X 5 10 8 3 
D E F G 


1 Literal é um valor fixo, definido quando se escreve o programa. Por exemplo: x :=10 . 3; onde 10.3 é um literal. vet: array [1..18] of 
char; onde 1 e 18, escritos dentro dos colchetes, são literais. 
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CONST MIN = 3; 
CONST MAX = 7; 
VAR V:ARRAY[MIN..MAX] OF INTEGER; 


V 14 5 8 65 71 
3 4 5 6 7 


6.2.4 Atribuindo valores ao vetor 


As atribuições em vetor exigem que seja informada em qual de suas posições o valor ficará armazenado. 


x[4]:=5; atribui o valor 5 à posição do vetor cujo índice é 4. 
VET[3]:='F'; atribui a letra F à posição do vetor cujo índice é 3. 
y['d']:=4.1; atribui o valor 4.1 à posição do vetor cujo índice é o caractere d. 


6.2.5 Preenchendo um vetor 


Preencher um vetor significa atribuir valores a todas as suas posições. Assim, deve-se implementar um 
mecanismo que controle o valor do índice. 


Exemplo 1: 
FOR i:= 1 TO 7 DO 
BEGIN 
READLN(X[i]); 
END; 
Exemplo 2: 
FOR i:= 'C' TO 'E' DO 
BEGIN 
READLN(X[i]); 
END; 


O exemplo 1 apresentou uma estrutura de repetição FOR, que foi utilizada para garantir que a variável i 
assumisse todos os valores possíveis para o índice do vetor (de 1 a 7). Já o exemplo 2 utilizou uma estrutura 
de repetição for para garantir que a variável i assumisse todos os valores possíveis entre os caracteres C e 
E. Assim, para cada execução da repetição, uma posição diferente dos vetores será preenchida por um valor 
digitado pelo usuário. 


6.2.6 Mostrando os elementos do vetor 


Mostrar os valores contidos em um vetor também exige a utilização do índice. 


Exemplo 1: 
FOR i:=1 TO 10 DO 
BEGIN 

WRITELN(X[i]); 
END; 
Exemplo 2: 
FOR i:= 'C' TO 'E' DO 
BEGIN 


WRITELN(X[i]); 
END; 
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O exemplo 1 apresentou uma estrutura de repetição FOR, que foi utilizada para garantir que a variável 
i assumisse todos os valores possíveis para o índice do vetor (de 1 a 10). Já no exemplo 2, a estrutura de 
repetição FOR garantiu que a variável i assumisse todos os valores possíveis entre os caracteres C e E. As- 
sim, para cada execução da repetição, foi utilizada uma posição diferente do vetor e, dessa forma, todos os 
valores armazenados foram mostrados. 


6.3 Vetor em C/C++ 


6.3.1 Definição de vetor 


As variáveis compostas homogêneas unidimensionais (ou, simplesmente, vetores) são capazes de arma- 
zenar diversos valores. Cada um desses valores é identificado pelo mesmo nome (o nome dado ao vetor), 
sendo diferenciados entre si apenas por um índice. 

Os índices utilizados na linguagem C/C++ para identificar as posições de um vetor começam sempre em 
O (zero) e vão até o tamanho do vetor menos uma unidade. O índice de um vetor em C/C++ deve sempre ser 
representado por um dos tipos inteiros disponíveis na linguagem. 


6.3.2 Declaração de vetor 


Os vetores em C/C++ são identificados pela existência de colchetes logo após o nome da variável no 
momento da declaração. Dentro dos colchetes, deve-se colocar o número de elementos que o vetor poderá 
armazenar. 

Em C/C++, a indicação do tamanho do vetor (ou seja, a quantidade de elementos que o vetor poderá 
armazenar) deve ser feita por um valor inteiro fixo (representado por um literal? ou uma constante). Se hou- 
ver necessidade de definir o tamanho do vetor em tempo de execução, deve-se fazê-lo através de ponteiros 
(o Capítulo 8 apresentará o conceito de ponteiro). 


6.3.3 Exemplo de vetor 
A seguir, são apresentadas algumas formas de criação de vetores. 


Exemplo 1: 


int vet[10]; 


vet 10 5 3 8 1 19 44 21 2 7 


No exemplo 1, o vetor chamado vet possui dez posições, começando pela posição 0 e indo até a po- 
sição 9 (tamanho do vetor — 1). Em cada posição poderão ser armazenados números inteiros, conforme 
especificado pelo tipo int na declaração. 


Exemplo 2: 


char x[5]; 


X A X 
(0) 1 2 3 4 


No exemplo 2, o vetor chamado x possui cinco posições, começando pela posição 0 e indo até a posição 
4 (tamanho do vetor — 1). Em cada posição poderão ser armazenados caracteres, conforme especificado 
pelo tipo char na declaração. 


2 Literal é um valor fixo, definido quando se escreve o programa. Por exemplo: double x=10.3; onde 10.3 é um literal. char vet [18]; 
onde 18, escrito dentro dos colchetes, é um literal. 
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Exemplo 3: 


define tam 5; 
char z[tam]; 


A y 2 @ K 
1 2 3 4 


No exemplo 3, o vetor z tem tamanho 5, exatamente o valor definido para a constante chamada tam. 

É importante ressaltar que, na linguagem C, não existe o tipo de dado string (que será visto em deta- 
lhes no Capítulo 9), como ocorre na linguagem PASCAL. Dessa maneira, por exemplo, para poder armaze- 
nar o nome completo de uma pessoa, em uma cadeia de caracteres, deve-se declarar um vetor de char, em 
que cada posição equivale a um caractere ou a uma letra do nome. Além disso, toda vez que se faz uso de 
um vetor para armazenar uma cadeia de caracteres, deve-se definir uma posição a mais que a necessária, 
pois esta armazenará a marca de finalização de cadeia, representada pelo caractere "No". 


6.3.4 Atribuindo valores ao vetor 


As atribuições em vetor exigem que seja informada em qual de suas posições o valor ficará armazenado. 
Lembre-se: sempre a primeira posição de um vetor em C/C++ tem índice 0. 


vet[0] = 1; atribui o valor 1 à primeira posição do vetor (lembre-se de que o vetor começa na 
posição zero). 
x[3] = 'b'; atribui a letra b à quarta posição do vetor (lembre-se de que o vetor começa na 


posição zero). 


6.3.5 Preenchendo um vetor 


Preencher um vetor significa atribuir valores às suas posições. Assim, deve-se implementar um mecanis- 
mo que controle o valor do índice. 


for (i=0; i<l0; i++) 
scanf(“2d$*c”, &vetor[i]); 
Nesse exemplo, a estrutura de repetição FoR foi utilizada para garantir que a variável i assumisse todos 


os valores possíveis para o índice do vetor (de O a 9). Assim, para cada execução da repetição, será utilizada 
uma posição diferente do vetor. 


6.3.6 Mostrando os elementos do vetor 
Mostrar os valores contidos em um vetor também exige a utilização de um índice. 


for (i=0; i<l0; i++) 
printf(“2d”, vetor[il; 


Nesse exemplo, a estrutura de repetição FoR foi utilizada para garantir que a variável i 


assumisse todos os valores possíveis para o índice do vetor (de O a 9). Assim, para cada execução da repeti- 
ção, foi utilizada uma posição diferente e, dessa forma, todos os valores do vetor foram mostrados. 


6.4 Vetor em JAVA 


6.4.1 Definição de vetor 


As variáveis compostas homogêneas unidimensionais (vetores) são variáveis capazes de armazenar di- 
versos valores. Cada um desses valores é identificado pelo mesmo nome (o nome dado ao vetor), sendo 
diferenciados entre si apenas por um índice. 

Os índices utilizados na linguagem JAVA para identificar as posições de um vetor começam sempre em 
O (zero) e vão até o tamanho do vetor menos uma unidade. 
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6.4.2 Declaração de vetor 


Os vetores em JAVA são definidos pela existência de colchetes vazios antes ou depois do nome da variável, 
no momento da declaração. Logo depois, deve ser feito o dimensionamento do vetor. 

Em JAVA, a indicação do tamanho do vetor (ou seja, a quantidade de elementos que o vetor poderá 
armazenar) pode ser feita por um valor inteiro fixo (representado por um literal? ou uma constante) ou por 
uma variável cujo valor é definido em tempo de execução. 


6.4.3 Exemplo de vetor 


Nos exemplos a seguir, são utilizadas duas linhas de comando: a primeira declara um vetor e a segunda 
define o seu tamanho. 


Exemplo 1: 


int x[]; 
x = new int[10]; 


X 10 5 3 8 1 19 44 21 2 7 
o 1 2 3 4 5 6 7 8 9. 


Na primeira linha do exemplo 1, os colchetes vazios após o nome definem que x será um vetor. O tipo 
int determina que todas as suas posições armazenarão valores inteiros. A segunda linha estabelece que o 
vetor x terá tamanho 10 (ou seja, posições de 0 a 9). 


Exemplo 2: 


final int tam=6; 
float []y; 
y = new float[tam]; 


Y 1.5 8.9 3.0 4.7 15.3 16.0 
0 1 2 3 4 5 


Na primeira linha do exemplo 2, foi definida a constante tam, com valor igual a 6. Na segunda linha, 
os colchetes vazios antes do nome definem que y será um vetor. O tipo float determina o tipo do conteúdo 
que poderá ser armazenado em todas as suas posições. A terceira linha estabelece que o vetor y terá tama- 
nho 6, exatamente o valor da constante tam (ou seja, o vetor terá posições de O a 5). 


Exemplo 3: 


double w[]; 

int tam; 

tam = ent.nextInt(); 
w = new double[tam]; 


Y 1.5 8.9 3.0 4.7 15.3 16.0 ata 16.0 
(0) 1 2 3 4 5 e tam-1 


No exemplo 3, tem-se um vetor cujo tamanho dependerá de um valor fornecido no momento da execu- 
ção do programa. Na primeira linha do exemplo 3, os colchetes vazios depois do nome, definem que w será 
um vetor. O tipo double, determina o tipo do dado que poderá ser armazenado em todas as suas posições. 
Na segunda linha é declarada a variável tam, que, após receber um valor externo (terceira linha), indicará o 
tamanho do vetor w (quarta linha). 

Já, nos exemplos apresentados a seguir, utilizou-se a forma condensada, onde a declaração e o dimen- 
sionamento do vetor são feitos utilizando-se uma única linha. 


3 Literal é um valor fixo, definido quando se escreve o programa. Por exemplo: double x=10.3; onde 10.3 é um literal. char vet 
[]= new char[18]; onde 18, escrito dentro dos colchetes, é um literal. 
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Exemplo 4: 
final int tam = 8; 
int x[] = new int[tam]; 
X 5 9 1 14 25 5 18 (0) 
(0) 1 2 5 4 5 6 7 


O exemplo 4 faz uso da constante tam para especificar o tamanho do vetor x. Na segunda linha do 
exemplo, a parte que antecede o sinal de igual informa que x é um vetor e que poderá armazenar números 
inteiros. À parte que sucede o sinal de igual dimensiona o tamanho de x em 8 (posições de O a 7). 


Exemplo 5: 


char []y = new char[5]; 


O exemplo 5 define e dimensiona o vetor y utilizando uma única linha. Assim, a parte que antecede o 
sinal de igual informa que y é um vetor e que poderá armazenar qualquer caractere. A parte que sucede o 
sinal de igual dimensiona o tamanho de y em 5 (posições de O a 4). 


6.4.4 Atribuindo valores ao vetor 


As atribuições em vetor exigem que seja informada em qual de suas posições o valor ficará armazenado. 
Deve-se lembrar sempre que a primeira posição de um vetor em JAVA tem índice 0. 


vet[0] = 1; atribui o valor 1 à primeira posição do vetor (lembre-se de que o vetor começa na 
posição 0). 

x[3] = 'b'; atribui o valor b à quarta posição do vetor (lembre-se de que o vetor começa na 
posição 0). 


6.4.5 Preenchendo um vetor 


Preencher um vetor significa atribuir valores a todas as suas posições. Assim, deve-se implementar um 
mecanismo que controle o valor do índice. 
e = new Scanner(System.in); 
for (i=0; i<l0; i++) 
vet[i] = e.nextInt(); 


Nesse exemplo, a estrutura de repetição FoR foi utilizada para garantir que a variável i assumisse todos 
os valores possíveis para o índice do vetor (de O a 9). Assim, para cada execução da repetição, uma posição 
diferente do vetor será utilizada. 


6.4.6 Mostrando os elementos do vetor 


Mostrar os valores contidos em um vetor também implica na utilização do índice. 


for (i=0; i<l0; i++) 
System.out.println(vet[i]); 


Nesse exemplo, a estrutura de repetição FoR foi utilizada para garantir que a variável i assumisse todos 
os valores possíveis para o índice do vetor (de O a 9). Assim, para cada execução da repetição, será utilizada 
uma posição diferente e, dessa forma, todos os valores do vetor serão mostrados. 
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EXERCÍCIOS RESOLVIDOS 


BEER Faça um programa que preencha um vetor com nove números inteiros, calcule e mostre os números 
primos e suas respectivas posições. 


(AILISIOJRN TIM) Sorução: 


ALGORITMO 
DECLARE num[9] NUMÉRICO 
i, j, cont NUMÉRICO 
PARA i — 1 ATÉ 9 FAÇA 
INÍCIO 
LEIA num[i] 
FIM 
PARA i — 1 ATÉ 9 FAÇA 
INÍCIO 
cont — 0 
PARA j — 1 ATÉ num[i] FAÇA 
INÍCIO 
SE RESTO(num[i]/j) = 0 
ENTÃO cont — cont + 1 
FIM 
SE cont <= 2 
ENTÃO INÍCIO 
ESCREVA num[i] 
ESCREVA i 
FIM 
FIM 
FIM ALGORITMO. 


INST OH SOLUÇÃO: 
VEXERCICAP6 VPASCALVEX1.PAS e VEXERCICAP6)PASCALNEX1.EXE 


GEE 
oPAeR Ra SoLução: 
E \EXERC\CAP6\C++\EX1.CPP e NEXERCACAP6NC++NEX1. EXE 


RB WIAN SoLução: 
EEE VEXERCICAP6 JAVANEX1. java e \EXERC\CAP6\JAVA\EX1.class 


EM Uma pequena loja de artesanato possui apenas um vendedor e comercializa dez tipos de objetos. O 
vendedor recebe, mensalmente, salário de R$ 545,00, acrescido de 5% do valor total de suas vendas. 
O valor unitário dos objetos deve ser informado e armazenado em um vetor; a quantidade vendida de 
cada peça deve ficar em outro vetor, mas na mesma posição. Crie um programa que receba os preços 
e as quantidades vendidas, armazenando-os em seus respectivos vetores (ambos com tamanho dez). 
Depois, determine e mostre: 


um relatório contendo: quantidade vendida, valor unitário e valor total de cada objeto. Ao final, 
deverão ser mostrados o valor geral das vendas e o valor da comissão que será paga ao vendedor; e 


o valor do objeto mais vendido e sua posição no vetor (não se preocupe com empates). 
(AJLIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE qgtd[10], preco[10] NUMÉRICO 
i, tot geral, tot vend, comissao, maio, ind NUMÉRICO 
tot geral < 0 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA qtd[i] 
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LEIA preco[i] 
FIM 
PARA i e 1 ATÉ 10 FAÇA 
INÍCIO 
tot vend <— aqtd[i] * preco[i] 
ESCREVA gtd[il], preço[i], tot vend 
tot geral <— tot geral + tot vend 
FIM 
comissão <— tot geral * 5 /100 
ESCREVA tot geral, comissao 
maior + qtd[1] 
tnde dl 
PARA i 4— 2 ATÉ 10 FAÇA 
INÍCIO 
SE qtd[i] > maior 
ENTÃO INÍCIO 
maior <— qtd[i] 
alinkol <= at 
FIM 
FIM 
ESCREVA preco[ ind], ind 
FIM ALGORITMO. 


PASCAL SoLução: 


\EXERC\CAP6\PASCAL\EX2.PAS e \EXERC\CAP6\PASCAL\EX2.EXE 


[26 A 
C/C++ EO 
= \EXERC\CAP6\C++\EX2.CPP e \EXERC\CAP6\C++\EX2. EXE 


RNA SoLução: 


D \EXERC\CAP6\JAVA\EX2.java e \EXERC\CAP6\JAVA\EX2.class 


IEA Faça um programa que preencha dois vetores de dez elementos numéricos cada um e mostre o vetor resultante 


da intercalação deles. 


Vetor 1 3 5 4 2 2 5 
1 2 4 4 5 

Vetor 2 7 15 20 (o) 18 4 
1 2 4 4 5 6 


Vetor resultante da intercalação 


3 |7 |5 |15|/4 120]2 |O |2 |18]5 1413 


1 2 3 4 5 6 7 8 9 10 11 12 13 14 


(ALLISIOJEN ITIMO) Solução: 


ALGORITMO 


DECLARE vet1[10], vet2[10], vet3[20] NUMÉRICO 


i, j NUMÉRICO 
ap = 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vetl[i] 
vet3[)] < vetl[i] 


16 17 


5 9 
9 10 
8 6 
9 10 
8 9 6 
18 19 20 
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gs a) sr dl 
LEIA vet2[i] 
vet3[j] — vet2[i] 
aj So a) ar dt 
FIM 
PARA i < 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA vet3[i] 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
D \EXERC\CAP6\PASCAL\EX3.PAS e \EXERC\CAP6\PASCAL\EX3.EXE 


Loea SoLução: 
= \EXERC\CAP6\C++\EX3.CPP e \EXERC\CAP6\C++\EX3.EXE 


RB WIA NA SoLução: 
ED \EXERC\CAP6\JAVA\EX3.java e \EXERC\CAP6\JAVA\EX3.class 


LH Faça um programa que preencha um vetor com oito números inteiros, calcule e mostre dois vetores 
resultantes. O primeiro vetor resultante deve conter os números positivos e o segundo, os números ne- 
gativos. Cada vetor resultante vai ter, no máximo, oito posições, que não poderão ser completamente 
utilizadas. 


(AJLIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE num[8], pos[8], neg[8] NUMÉRICO 
cont, cont n, cont p, i NUMÉRICO 
Contini 
contipke I 
PARA i <— 1 ATÉ 8 FAÇA 
INÍCIO 
LEIA num[i] 
SE num[i] >= 0 
ENTÃO INÍCIO 
pos[cont p] — num[i] 
cont p < cont p+ 1 
FIM 
SENÃO INÍCIO 
neg[cont n] <— num[i] 
cont n < cont m t I 
FIM 
FIM 
SE contn = 1 
ENTÃO ESCREVA “Vetor de negativos vazio” 
SENÃO INÍCIO 
PARA i < 1 ATÉ cont_n — 1 FAÇA 
INÍCIO 
ESCREVA neg[i] 
FIM 
FIM 
SE cont_p = 1 
ENTÃO ESCREVA “Vetor de positivos vazio” 
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SENÃO INÍCIO 
PARA i — 1 ATÉ cont p — 1 FAÇA 
INÍCIO 
ESCREVA pos[i] 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
GERE \EXERC\CAP6\PASCAL\EX4.PAS e NEXERCACAP6YPASCALNEX4 .EXE 


VETA Solução: 
Ee À \EXERC\CAP6\C++\EX4.CPP e NEXERCACAP6NC++NEX4. EXE 


JAVA SoLuçÃo: 
D \EXERC\CAP6\JAVA\EX4.java e \EXERC\CAP6\JAVA\EX4.class 


EME Faça um programa que preencha dois vetores, X e Y, com dez números inteiros cada. Calcule e mostre 
os seguintes vetores resultantes: 


A união de X com Y 
(todos os elementos de X e de Y sem repetições). 


x 5 2 1 6 8 7 11 9 
1 3 5 6 7 8 9 10 

y 2 1 5 12 5 0 1 4 5 6 
1 2 3 4 5 6 7 8 9 10 

União 3 8 4 2 1 6 7 11 9 5 12 (o) 
1 2 5 4 5 6 7 8 9 10 11 12 


A diferença entre X e Y 
(todos os elementos de X que não existam em Y, sem repetições). 


X 5 8 4 2 1 6 8 Fá 11 9 
1 2 3 4 5 6 7 8 9 10 
y 2 1 5 12 3 0 1 4 5 6 
1 2 5 4 5 6 7 8 9 10 
Diferença 8 7 11 9 
1 2 3 4 


A soma entre X e Y 
(soma de cada elemento de X com o elemento de mesma posição em Y). 


x 3 8 4 2 1 6 8 7 11 9 

1 2 3 4 5 6 7 8 9 10 

y 2 1 5 12 3 0 1 4 5 6 

1 2 3 4 5 6 7 8 9 10 

Soma 5 9 9 14 4 6 9 11 16 15 
1 2 3 4 5 6 7 8 9 10 


O produto entre X e Y 
(multiplicação de cada elemento de X com o elemento de mesma posição em Y). 
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y 2 1 5 12 3 (0) 
1 2 3 4 6 

Produto 6 8 20 24 3 0 
1 2 3 4 5 6 


A intersecção entre X e Y 


(apenas os elementos que aparecem nos dois vetores, sem repetições). 


x 3 8 2 1 6 
1 2 4 5 6 
y 2 1 12 5 0 
1 2 3 
Intersecção 3 4 2 ] 
1 2 3 4 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 


DECLARE X[10], Y[10], U[20], D[10], S[10], P[10], IT[10] NUMÉRICO 


i, j, k, cont u, cont d, cont i NUMÉRICO 
PARA i — 1 ATÉ 10 FAÇA 


INÍCIO 
LEIA X[i] 
LEIA Y[i] 
FIM 


cont bl «> dl 
cont d < 1 
one dd — dl 
PARA i + 1 ATÉ 10 FAÇA 


INÍCIO 
a) => dl 
ENQUANTO (j < cont u E X[i] = U[j]) FAÇA 
INÍCIO 
Djs ap he dh 
FIM 


SE j >= cont u 
ENTÃO INÍCIO 
Ulcont u] — X[i] 
cont u — cont u+1 
FIM 
FIM 
PARA i + 1 ATÉ 10 FAÇA 
INÍCIO 
J = dl 
ENQUANTO (j < cont u E Y[i] = U[j]) FAÇA 
INÍCIO 
asa ar nd 
FIM 
SE j >= cont u 
ENTÃO INÍCIO 
Ulcont u] — Y[i] 
cont u < contu+1 
FIM 
FIM 
PARA i + 1 ATÉ cont u - 1 FAÇA 


54 
10 
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INÍCIO 
ESCREVA U[i] 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
af ES al 
ENQUANTO (X[i] = Y[j] E j <= 10) FAÇA 
INÍCIO 
jo j+1 
FIM 
SE j > 10 
ENTÃO INÍCIO 
k 1 
ENQUANTO (k < cont d E X[i] = D[k]) FAÇA 
INÍCIO 
k—- k+1 
FIM 
SE k >= cont d 
ENTÃO INÍCIO 
D[cond d] — X[i] 
cont_d + cont_d + 1 
FIM 
FIM 
FIM 
PARA i + 1 ATÉ cont d - 1 FAÇA 
INÍCIO 
ESCREVA (D[i]) 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
Sli] — X[i] + Y[i] 
P[i] — X[i] * Y[i] 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA S[i] 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA P[i] 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
aj se dl 
ENQUANTO (j <= 10 E X[i] = Y[j]) FAÇA 
INÍCIO 
aj e Sar dh 
FIM 
SE j <= 10 
ENTÃO INÍCIO 
k — 1 
ENQUANTO (k < cont i E IT[k] = X[i])FAÇA 
INÍCIO 
k -k+1 
FIM 


SE k >= cont i 
ENTÃO INÍCIO 
IT[cont i] — X[i] 


Capítulo 6 Vetor | 165 


come cont 


FIM 
FIM 
FIM 
PARA i + 1 ATÉ cont i — 1 FAÇA 
INÍCIO 
ESCREVA IT[i] 
FIM 


FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
Ea! \EXERC\CAP6\PASCAL\EX5.PAS e NEXERCACAP6VPASCALNEX5. EXE 


eylen Ra SoLução: 
GER \EXERC\CAP6\C++\EX5.CPP e NEXERCACAP6NC++NEX5. EXE 


RAIA SOLUÇÃO: 
Rss NEXERCÍCAP6 JAVANEX5. java e VEXERCICAP6JAVANEX5.class 


[EM Faça um programa que preencha um vetor com dez números inteiros, calcule e mostre o vetor resul- 
tante de uma ordenação decrescente. 


x 3 2 1 6 11 9 
1 5 6 9 10 

Ordenado 11 9 8 7 6 5 1 
1 2 10 


(AILIGIOJRILITIMO) SoLução: 


ALGORITMO 


DECLARE vet [10], i, j, aux NUMÉRICO 
PARA — 1 ATÉ 10 FAÇA 


INÍCIO 
LEIA vet[i] 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 9 FAÇA 
INÍCIO 
SE vet[j] < vet[j+1] 
ENTÃO INÍCIO 
aux — vet[5] 
vet[j] — vet[J+1] 
vet[j+1] — aux 
FIM 
FIM 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA vet[i] 
FIM 


FIM ALGORITMO. 
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PASCAL SOLUÇÃO: 
D \EXERC\CAP6\PASCAL\EX6.PAS e \EXERC\CAP6\PASCAL\EX6.EXE 


eylen Ra SoLuçÃO: 
D \EXERC\CAP6\C++\EX6.CPP e \EXERC\CAP6\C++\EX6 .EXE 


JAVA SoLuçÃo: 
E \EXERC\CAP6\JAVA\EX6.java e \EXERC\CAP6\JAVA\EX6.class 


IEA Faça um programa que, no momento de preencher um vetor com oito números inteiros, já os armazene 
de forma crescente. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE vet [8], i, j, Z, aux NUMÉRICO 
at, = dl 
ENQUANTO (i <= 8) FAÇA 
INÍCIO 
LEIA aux 
ap fes cdl 
ENQUANTO (j < i E vet[j] < aux) FAÇA 
INÍCIO 
a e) E 
FIM 
= = 
ENQUANTO (z >= j+1) FAÇA 
INÍCIO 
vet[z] — vet[z-1] 
a m= po À 
FIM 
vet[j] — aux 
i — i+ 1 
FIM 
PARA i <— 1 ATÉ 8 FAÇA 
INÍCIO 
ESCREVA vet[i] 
FIM 
FIM_ALGORITMO. 


INNA 12 SOLUÇÃO — UTILIZANDO APENAS WHILE: 
e) VEXERCNCAP6 VPASCALNEX7 A.PAS e VEXERCICAP6NPASCALNEX7 A.EXE 


22 soLUÇÃO — UTILIZANDO FOR E WHILE: 

VEXERCICAP6 NPASCALNEX7 B.PAS e NEXERCICAP6PASCALNEX7 B.EXE 
LESA 1? soLução — UTILIZANDO APENAS WHILE: 
CEER \EXERC\CAP6\C++\EX7_A.CPP e \EXERC\CAP6\C++\EX7_A.EXE 
eS 


22 soLUÇÃO — UTILIZANDO FOR E WHILE: 
VEXERCICAP6NC++NEX7 B.CPP e NEXERCICAP6ICHEX7 B.EXE 


BAIANA 12 soLução — UTILIZANDO APENAS WHILE: 
VEXERCACAP6NJAVANEX7 A.java e NEXERCICAP6JAVANEX7 A.class 


22 soLUÇÃO — UTILIZANDO FOR E WHILE: 
VEXERCICAP6NJAVANEX7 B.java e VEXERCICAP6JAVANEX7 B.class 
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REA Faça um programa que preencha dois vetores com cinco elementos numéricos cada e, depois, ordene- 
-os de maneira crescente. Deverá ser gerado um terceiro vetor com dez posições, composto pela junção 
dos elementos dos vetores anteriores, também ordenado de maneira crescente. 


x 6 8 1 10 
1 2 3 4 5 
X 1 3 6 8 10 
ordenado 1 2 3 4 5 
y 20 (0) 7 2 
1 2 
Y 0 2 5 7 20 
Ordenado 1 2 3 4 5 
Resultado 0 1 2 3 5 6 7 8 10 20 
l 2 3 4 5 6 7 8 9 10 


(AILIGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE X[5], Y[5], R[10], i, j, z, aux NUMÉRICO 
PARA i — 1 ATÉ 5 FAÇA 


INÍCIO 
LEIA X[i] 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
SE X[j] > X[j+1] 
ENTÃO INÍCIO 
aux — X[5] 
X[j] — X[5+1] 
X[j+1] — aux 
FIM 
FIM 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA Y[i] 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j < 1 ATÉ 4 FAÇA 
INÍCIO 
SE Y[j] > Y[j+1] 
ENTÃO INÍCIO 
aux — Y[5] 
Y[5] — Y[j+1] 
Y[j+1] — aux 
FIM 
FIM 
FIM 


3) = dj 
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PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
R[5] — X[i] 
jJ—oj+1 
R[5] — Yei 
j=j+1 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 9 FAÇA 
INÍCIO 
SE R[j] > R[j+1] 
ENTÃO INÍCIO 
aux — R[5] 
R[5] — R[j+1] 
R[j+1] — aux 
FIM 
FIM 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
ESCREVA X[i] 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
ESCREVA Y[i] 
FIM 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA R[i] 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
[E \EXERC\CAP6\PASCAL\EX8.PAS e NEXERCACAP6YPASCALNEX8.EXE 


Lona SoLução: 
\EXERC\CAP6\C++\EX8.CPP e NEXERCACAP6NC++NEX8. EXE 


HER 
RNA SoLução: 
Ens VEXERCICAP6 JAVANEX8. java e \EXERC\CAP6\JAVA\EX8.class 


REA Faça um programa que efetue reserva de passagens aéreas de uma companhia. O programa deverá ler 
informações sobre os voos (número, origem e destino) e o número de lugares disponíveis para doze 
aviões (um vetor para cada um desses dados). Depois da leitura, o programa deverá apresentar um 
menu com as seguintes opções: 


consultar; 
efetuar reserva; e 


sair. 
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Quando a opção escolhida for Consultar, deverá ser disponibilizado mais um menu com as seguintes 
opções: 
por número do voo; 
por origem; e 
por destino. 
Quando a opção escolhida for Efetuar reserva, deverá ser perguntado o número do voo em que a pes- 
soa deseja viajar. O programa deverá dar as seguintes respostas: 


reserva confirmada — caso exista o voo e lugar disponível, dando baixa nos lugares disponíveis; 
voo lotado — caso não exista lugar disponível nesse voo; 


voo inexistente — caso o código do voo não exista. 
A opção Sair é a única que permite encerrar a execução do programa. Sendo assim, após cada operação 
de consulta ou reserva, o programa volta ao menu principal. 


(AILIGIOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE voo[12], lugares[12], i, op, Oop2, num voo NUMÉRICO origem[12], destino[12], 
local LITERAL 
PARA i — 1 ATÉ 12 FAÇA 
INÍCIO 
LEIA voo[i] 
LEIA origem[i] 
LEIA destino[i] 
LEIA lugares[i] 
FIM 
REPITA 
ESCREVA “1- Consultar” 
ESCREVA “2- Reservar” 
ESCREVA “3- Finalizar” 
ESCREVA “Digite sua opção: “ 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
ESCREVA “1- Consulta por voo” 
ESCREVA “2- Consulta por origem” 
ESCREVA “3- Consulta por destino” 
ESCREVA “Digite sua opção: “ 
LEIA op2 
SE op2 = 1 
ENTÃO INÍCIO 
ESCREVA “Digite o número de voo: “ 
LEIA num voo 
i — 1 
ENQUANTO (i <= 12 E voo[i] * num voo) FAÇA 
INÍCIO 
i — i+ 1 
FIM 
SE i > 12 
ENTÃO ESCREVA “Voo inexistente “ 
SENÃO INÍCIO 
ESCREVA “Número do voo: “, voo[i] 
ESCREVA “Local de origem: “, origem[i] ESCREVA “Local de 
destino: “, destino[i] 
ESCREVA “Lugares disponíveis: “, lugares[i] 
FIM 
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FIM 
SE op2 = 2 
ENTÃO INÍCIO 
ESCREVA “Digite o local de origem:” 
LEIA local 
PARA i — 1 ATÉ 12 FAÇA 
INÍCIO 
SE local = origem[i] 
ENTÃO INÍCIO 
ESCREVA “Número do voo: “, voo[i] 
ESCREVA “Local de origem: “ , origem[i] 
ESCREVA “Local de destino: “, destino[i] 


ESCREVA “Lugares disponíveis: “, lugares[i] 
FIM 
FIM 
FIM 
SE op2 = 3 


ENTÃO INÍCIO 
ESCREVA “Digite o local de destino: “” 
LEIA local 
PARA i — 1 ATÉ 12 FAÇA 
INÍCIO 
SE local = destino[i] 
ENTÃO INÍCIO 
ESCREVA “Número do voo: “, voo[i] 
ESCREVA “Local de origem: “, origem[i] 
ESCREVA “Local de destino: “, destino[i] 
ESCREVA “Lugares disponíveis: “, lugares[i] 
FIM 
FIM 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
ESCREVA “Digite o número do voo desejado: “ 
LEIA num voo 
i — 1 
ENQUANTO (i < = 12 E voo[i] num voo) FAÇA 
INÍCIO 


FIM 
SE i > 12 
ENTÃO ESCREVA “Número de voo não encontrado “ 
SENÃO INÍCIO 
SE lugares[i] = 0 
ENTÃO ESCREVA “Voo lotado “ 
SENÃO INÍCIO 
lugares[i] = lugares[i] - 1 
ESCREVA “Reserva confirmada !” 
FIM 
FIM 
FIM 
ATÉ (op = 3) 
FIM ALGORITMO. 
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QQQ Observações 


A comparação de duas cadeias de caracteres (como dois nomes, por exemplo) em PASCAL 
é feita utilizando-se o sinal de = . As funções de manipulação de strings desta linguagem serão 
abordadas no Capítulo 9. 


Exemplo: 


{faz distinção entre maiúsculas e minúsculas} 
if (nomel = nome2) 
then writeln('Nomes iguais'); 


A comparação de duas cadeias de caracteres (como dois nomes, por exemplo) em C é feita 
utilizando-se algumas funções da biblioteca string.h. As funções de manipulação de strings 
desta linguagem serão abordadas no Capítulo 9. 


Exemplos: 


// faz distinção entre maiúsculas e minúsculas 
if (strcmp(nomel,nome2)==0) 
printf(“Nomes iguais”); 


// NÃO faz distinção entre maiúsculas e minúsculas 
if (strcmpi (nomel,nome2)==0) 
printf(“Nomes iguais”); 


A comparação de duas cadeias de caracteres (como dois nomes, por exemplo) em JAVA é 
feita utilizando-se alguns métodos da classe string. Os métodos de manipulação de strings 
desta linguagem serão abordados no Capítulo 9. 


Exemplos: 


// faz distinção entre maiúsculas e minúsculas 
if (nomel.equals (nome2)) 
System.out.println(“Nomes iguais”); 


// NÃO faz distinção entre maiúsculas e minúsculas 
if (nomel.equalsIgnoreCase(nome2)) 
System.out.println(“Nomes iguais”); 


PASCAL SOLUÇÃO: 
GERE \EXERC\CAP6\PASCAL\EX9.PAS e NEXERCACAP6YPASCALNEX9. EXE 


eylen Ra SoLução: 
D \EXERC\CAP6\C++\EX9.CPP e \EXERC\CAP6\C++\EX9 . EXE 


RB WIAN SoLução: 
CE \EXERC\CAP6\JAVA\EX9.java e \EXERC\CAP6\JAVA\EX9.class 


ELA Faça um programa para corrigir provas de múltipla escolha. Cada prova tem oito questões e cada 
questão vale um ponto. O primeiro conjunto de dados a ser lido é o gabarito da prova. Os outros da- 


dos são os números dos alunos e as respostas que deram às questões. Existem dez alunos matriculados. 
Calcule e mostre: 


o número e a nota de cada aluno; e 


a porcentagem de aprovação, sabendo-se que a nota mínima é 6. 
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(ALLISIOJRN INTIMO) Solução: 


ALGORITMO 
DECLARE gabarito[8], resposta LITERAL 
num, pontos, tot ap, perc ap, i, j NUMÉRICO 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA “Digite a resposta da questão “, i 
LEIA gabarito[i] 
FIM 
tot ap — 0 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA “Digite o número do “, i, “Q aluno” 
LEIA num 
pontos — 0 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
ESCREVA “Digite a resposta dada pelo aluno “, num, “ à “, j, “2 questão” 
LEIA resposta[j] 
SE resposta[j] = gabarito[5] 
ENTÃO pontos + pontos + 1 
FIM 
ESCREVA “A nota do aluno “, num, “ foi “, pontos 
SE pontos >= 6 
ENTÃO tot ap — tot ap + 1 
FIM 
perc ap — tot ap * 100 / 10 
ESCREVA “O percentual de alunos aprovados é ”, perc ap 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
E NEXERCACAP6NPASCALVEX10.PAS e VEXERCICAP6NPASCALNEX10.EXE 


LETSA SoLução: 
D \EXERC\CAP6\C++\EX10.CPP e \EXERC\CAP6\C++\EX10.EXE 


RANMA SoLução: 
GENE \EXERC\CAP6\JAVA\EX10.java e NEXERCICAP6JAVANEX10.class 


EEB Faça um programa que receba a temperatura média de cada mês do ano, armazenando-as em um vetor. 
Calcule e mostre a maior e a menor temperatura do ano e em que mês ocorreram (mostrar o mês por 
extenso: 1 — janeiro, 2 — fevereiro...). Desconsidere empates. 


(ALLISIOJEL ITIMO) Solução: 


ALGORITMO 
DECLARE temp[12], cont, maior, menor, maior mes, menor mes NUMÉRICO 
PARA cont <— 1 ATÉ 12 FAÇA 
INÍCIO 
LEIA temp[cont] 
SE (cont = 1) 
ENTÃO INÍCIO 
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maior + temp[cont] 
menor + temp[cont] 
maior mes « cont 
menor mes « cont 
FIM 
SENÃO INÍCIO 
SE (temp[cont] > maior) 
ENTÃO INÍCIO 
maior — temp[cont] 
maior mes < cont 
FIM 
SE (temp[cont] < menor) 
ENTÃO INÍCIO 
menor + temp[cont] 
menor mes « cont 
FIM 
FIM 
FIM 
ESCREVA maior 
SE (maior mes = 1) 
ENTÃO ESCREVA “JANEIRO” 
SE (maior mes = 2) 
ENTÃO ESCREVA “FEVEREIRO” 
SE (maior mes = 3) 
ENTÃO ESCREVA “MARÇO” 
SE (maior mes = 4) 
ENTÃO ESCREVA “ABRIL” 
SE (maior mes = 5) 
ENTÃO ESCREVA “MAIO” 
SE (maior mes = 6) 
ENTÃO ESCREVA “JUNHO” 
SE (maior mes = 7) 
ENTÃO ESCREVA “JULHO” 
SE (maior mes = 8) 
ENTÃO ESCREVA “AGOSTO” 
SE (maior mes = 9) 
ENTÃO ESCREVA “SETEMBRO” 
SE (maior mes = 10) 
ENTÃO ESCREVA “OUTUBRO” 
SE (maior mes = 11) 
ENTÃO ESCREVA “NOVEMBRO” 
SE (maior mes = 12) 
ENTÃO ESCREVA “DEZEMBRO” 
ESCREVA menor 
SE (menor mes = 1) 
ENTÃO ESCREVA “JANEIRO” 
SE (menor mes = 2) 
ENTÃO ESCREVA “FEVEREIRO” 
SE (menor mes = 3) 
ENTÃO ESCREVA “MARÇO” 
SE (menor mes = 4) 
ENTÃO ESCREVA “ABRIL” 
SE (menor mes = 5) 
ENTÃO ESCREVA “MAIO” 
SE (menor mes = 6) 
ENTÃO ESCREVA “JUNHO” 
SE (menor mes = 7) 
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ENTÃO ESCREVA “JULHO” 
SE (menor mes = 8) 

ENTÃO ESCREVA “AGOSTO” 
SE (menor mes = 9) 

ENTÃO ESCREVA “SETEMBRO” 
SE (menor mes = 10) 

ENTÃO ESCREVA “OUTUBRO” 
SE (menor mes = 11) 

ENTÃO ESCREVA “NOVEMBRO” 
SE (menor mes = 12) 

ENTÃO ESCREVA “DEZEMBRO” 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
(Es VEXERCACAP6NPASCALVEX11.PAS e NEXERCACAP6NPASCALNEX11.EXE 


C/C++ Sotução: 
GERE \EXERC\CAP6\C++\EX11.CPP e \EXERC\CAP6\C++\EX11.EXE 


NB WIA NA SoLução: 
D \EXERC\CAP6\JAVA\EX11.java e \EXERC\CAP6\JAVA\EX11.class 


EFA Faça um programa que preencha um vetor com os modelos de cinco carros (exemplos de modelos: Fusca, 
Gol, Vectra etc). Carregue outro vetor com o consumo desses carros, isto é, quantos quilômetros cada um 
deles faz com um litro de combustível. Calcule e mostre: 


o modelo de carro mais econômico; e 


quantos litros de combustível cada um dos carros cadastrados consome para percorrer uma distân- 


cia de 1.000 km. 
SoLução: 


ALGORITMO 
DECLARE consumo[5], menor cons, menor vei, valor, i NUMÉRICO 
veiculo[5] LITERAL 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA veiculo[i] 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA consumo[i] 
SE (i = 1) 
ENTÃO INÍCIO 
menor cons + consumo[i] 
menor vei — i 
FIM 
SENÃO INÍCIO 
SE (consumo[i] < menor cons) 
ENTÃO INÍCIO 
menor cons + consumo[i] 
menor vei + i 
FIM 
FIM 
valor — 1000 / consumo[i] 
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ESCREVA “ O veículo “ , veiculo[i], “ consome “ , valor, “litro(s) de combustível 
= para percorrer 1000 Km” 
FIM 
ESCREVA “O veículo mais econômico é “, veiculo[menor vei] 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
VEXERCACAP6NPASCALVEX12.PAS e NEXERCACAP6NPASCALNEX12.EXE 


GVLS SoLução: 
\EXERC\CAP6\C++\EX12.CPP e \EXERC\CAP6\C++\EX12.EXE 


SEGE SoLução: 
\EXERC\CAP6\JAVA\EX12.java e \EXERC\CAP6\JAVA\EX12.class 


EEJ Faça um programa que preencha um vetor com dez números inteiros, calcule e mostre os números su- 
periores a cinquenta e suas respectivas posições. O programa deverá mostrar mensagem se não existir 
nenhum número nessa condição. 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE vet [10], achou LÓGICO 
i NUMÉRICO 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vet[i] 
FIM 


achou < falso 
PARA i <— 1 ATÉ 10 FAÇA 
INÍCIO 
SE vet[i] > 50 
ENTÃO INÍCIO 
ESCREVA vet[i], i 
achou + verdadeiro 
FIM 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Não existem números superiores a 50 no vetor” 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
GRE \EXERC\CAP6\PASCAL\EX13.PAS e VEXERCICAP6NPASCALNEX13.EXE 


c/c++ Solução: 
GEES \EXERC\CAP6\C++\EX13.CPP e NEXERCACAP6NC++NEX13. EXE 


BAIA SOLUÇÃO: 
Es \EXERC\CAP6\JAVA\EX13.java e NEXERCICAP6JAVANEX13.class 


ELA Faça um programa que preencha três vetores com cinco posições cada. O primeiro vetor receberá os 
nomes de cinco funcionários; o segundo e o terceiro vetor receberão, respectivamente, o salário e o 
tempo de serviço de cada um. Mostre um primeiro relatório apenas com os nomes dos funcionários 
que não terão aumento; mostre um segundo relatório apenas com os nomes e os novos salários dos 
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funcionários que terão aumento. Sabe-se que os funcionários que terão direito ao aumento são aqueles 
que possuem tempo de serviço superior a cinco anos ou salário inferior a R$ 800,00. Sabe-se, ainda, 
que, se o funcionário satisfizer às duas condições anteriores, tempo de serviço e salário, o aumento 
será de 35%; para o funcionário que satisfazer apenas à condição tempo de serviço, o aumento será de 
25%; para aquele que satisfazer apenas à condição salário, o aumento será de 15%. 


(ALLISIoJRLITIMO) Solução: 


ALGORITMO 

DECLARE nome[5] LITERAL 

sal[5], quant[5], i, novo sal NUMÉRICO 

PARA i — 1 ATÉ 5 FAÇA 

INÍCIO 

LEIA nome[i] 

LEIA sal[i] 

LEIA quant [i] 

FIM 
PARA i — 1 ATÉ 5 FAÇA 

INÍCIO 

SE (quant[i] <= 5) E (sal[i] >= 800) 

ENTÃO ESCREVA nome[i] 

FIM 
PARA i — 1 ATÉ 5 FAÇA 

INÍCIO 

SE (quant[i] > 5) OU (sal[i] < 800) 

ENTÃO INÍCIO 

SE (quant[i] > 5) E (sal[i] < 800) 
ENTÃO novo sal <— sal[i] + salfi] * 35 / 100 
SENÃO SE (quant[i] > 5) 
ENTÃO novo sal + sal[i] + sal[i] * 25 / 100 
SENÃO novo sal + sal[i] + sal[i] * 15 / 100 
ESCREVA nome[i], novo sal 
FIM 

FIM 

FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
C \EXERC\CAP6\PASCAL\EX14.PAS e \EXERC\CAP6\PASCAL\EX14.EXE 


eylen Ra SoLuçÃO: 
O \EXERC\CAP6\C++\EX14.CPP e \EXERC\CAP6\C++\EX14.EXE 


E-MAN SoLução: 
EE VEXERCICAP6JAVANEX14. java e NEXERCICAP6JAVANEX14.class 


EA Faça um programa que preencha um primeiro vetor com dez números inteiros, e um segundo vetor 
com cinco números inteiros. O programa deverá mostrar uma lista dos números do primeiro vetor com 
seus respectivos divisores armazenados no segundo vetor, bem como suas posições. 

Exemplo de saída do programa: 


Num 5 | 12 4 7 10 3 5 6 23 16 


Divis 3 11 5 8 2 
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Número 5 
Divisível por 5 na posição 3 


Número 12 
Divisível por 3 na posição 1 
Divisível por 2 na posição 5 


Número 4 
Divisível por 2 na posição 5 


Número 7 
Não possui divisores no segundo vetor 


Número 10 
Divisível por 5 na posição 3 
Divisível por 2 na posição 5 


Para saber se um número é divisível por outro, deve-se testar o resto. 
Exemplo: RESTO(5/5) = 0 


(AILTSIOJRN TIMÃO) Solução: 


ALGORITMO 
DECLARE vet1[10], vet2[5], i, j NUMÉRICO 
achou LÓGICO 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vetl[i] 
FIM 
PARA i <— 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA vet2[i] 
FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
achou + falso 
ESCREVA vet1[i] 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
SE RESTO(vetl[il]/vet2[5j]) = 0 
ENTÃO INÍCIO 
ESCREVA “Divisível por “, vet2[j], “na posição “, j 
achou +— verdadeiro 
FIM 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Não possui divisores no segundo vetor” 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
Es \EXERC\CAP6\PASCAL\EX15.PAS e VEXERCICAP6NPASCALNEX15.EXE 


Oyla SoLução: 
GRE \EXERC\CAP6\C++\EX15.CPP e NEXERCÂCAP6NC++NEX15. EXE 


RNA SoLução: 
GERE VEXERCACAP6 JAVANEX15.java e NEXERCICAP6JAVANEX15.class 
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HA Faça um programa que preencha um vetor com dez números inteiros e um segundo vetor com cinco 
números inteiros. Calcule e mostre dois vetores resultantes. O primeiro vetor resultante será composto 
pelos números pares, gerados pelo elemento do primeiro vetor somado a todos os elementos do segundo 
vetor; o segundo será composto pelos números ímpares gerados pelo elemento do primeiro vetor somado 
a todos os elementos do segundo vetor. 


Primeiro vetor 4 7 5 8 2 15 9 6 10 11 
1 2 3 4 5 6 7 8 9 10 
Segundo vetor 3 4 5 8 2 
1 2 3 4 5 
4+3+4+5+8 +2 7+43+4+5+8+2 


Vetor resultante 1 26| 30|22|...] Vetor resultante 2 29 |27 |37|...) 


1 2 3 ... 1 2 3 


8+3+4+5+8+2 5+3+4+5+8+2 


(AILIGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE vet1[10], vet2[5] NUMÉRICO 
vet result1[10], vet result2[10] NUMÉRICO 
i, j, poslivrel, poslivre2, soma NUMÉRICO 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vetl[i] 
FIM 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA vet2[5] 
FIM 
poslivrel — 1 
poslivre?2 — 1 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
soma — vetl[i] 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
soma <— soma + vet2[5] 
FIM 
SE RESTO(soma/2) = 0 
ENTÃO INÍCIO 
vet resultl[poslivrel] — soma 
poslivrel — poslivrel + 1 
FIM 
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SENÃO INÍCIO 
vet result2[poslivre2] — soma 
poslivre2 — poslivre2 + 1 


FIM 
FIM 
PARA i — 1 ATÉ (poslivrel -1) FAÇA 
INÍCIO 
ESCREVA vet resultl[i] 
FIM 
PARA i — 1 ATÉ (poslivre2 -1) FAÇA 
INÍCIO 
ESCREVA vet result2[i] 
FIM 


FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
EEE VEXERCACAP6NPASCALVEX16.PAS e VEXERCICAP6NPASCALNEX16.EXE 


eylen Ra SoLução: 
GRE \EXERC\CAP6\C++\EX16.CPP e \EXERC\CAP6\C++\EX16.EXE 


RB WIAN SoLução: 
D \EXERC\CAP6\JAVA\EX16.java e \EXERC\CAP6\JAVA\EX16.class 


EFA Faça um programa que receba seis números inteiros e mostre: 
os números pares digitados; 
a soma dos números pares digitados; 
os números ímpares digitados; e 


a quantidade de números ímpares digitados. 


Vetor 2 4 5 6 3 7 


1 2 5 4 5 6 
Relatório 


Os números pares são: 
número 2 na posição 1 
número 4 na posição 
número 6 na posição 


e N 


Soma dos pares = 12 


Os números ímpares são: 
número 5 na posição 3 
número 3 na posição 5 
número 7 na posição 6 


Quantidade de ímpares = 3 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE num[6], i, soma, qtde NUMÉRICO 
achou LÓGICO 
PARA i < 1 ATÉ 6 FAÇA 
INÍCIO 
LEIA num[i] 
FIM 
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soma — 0 
achou + falso 
PARA i < 1 ATÉ 6 FAÇA 
INÍCIO 
SE RESTO(num[i]/2) = 0 
ENTÃO INÍCIO 
achou + verdadeiro 
ESCREVA num[i], i 
soma +— soma + num[i] 
FIM 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Nenhum número par foi digitado” 
SENÃO ESCREVA "Soma dos pares = ",soma 
qtde — 0 
achou + falso 
PARA i < 1 ATÉ 6 FAÇA 
INÍCIO 
SE RESTO(num[i]/2) = 0 
ENTÃO INÍCIO 
achou + verdadeiro 
ESCREVA num[i], i 
qtde — qtde + 1 
FIM 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Nenhum número ímpar foi digitado” 
SENÃO ESCREVA "Quantidade de ímpares = ",qtde 
FIM ALGORITMO. 


TARSO NH SOLUÇÃO: 
Ed VEXERCICAP6NPASCALVEX17.PAS e VEXERCACAP6NPASCALNEX17.EXE 


C/c++ SoLução: 
E \EXERC\CAP6\C++\EX17.CPP e \EXERC\CAP6\C++\EX17.EXE 


E-G- SoLução: 
RES \EXERC\CAP6\JAVA\EX17.java e NEXERCICAP6JAVANEX17.class 


EEJ Faça um programa que receba o número sorteado por um dado em vinte jogadas. Mostre os números 
sorteados e a frequência com que apareceram. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE dado[20] NUMÉRICO 
i, numl, num2, num3, num4, num5, num6 NUMÉRICO 
PARA i < 1 ATÉ 20 FAÇA 
INÍCIO 
LEIA dado[i] 
ENQUANTO (dado[i] < 1) OU (dado[i] > 6) FAÇA 
INÍCIO 
LEIA dado[i] 
FIM 
FIM 
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PARA i < 1 ATÉ 20 FAÇA 


INÍCIO 

ESCREVA dado[i] 

FIM 

numil — 0 

num? — 0 

num3 — 0 

num4 — 0 

num5 — 0 

num6 — 0 

PARA i < 1 ATÉ 20 FAÇA 
INÍCIO 


SE dado[i] = 1 

ENTÃO numl <— numl + 1 

SE dado[i] = 2 

ENTÃO num2 +— num2 + 1 

SE dado[i] = 3 

ENTÃO num3 <— num3 + 1 

SE dado[i] = 4 

ENTÃO num4 <— num4 + 1 

SE dado[i] = 5 

ENTÃO num5 <— num5 + 1 

SE dado[i] = 6 

ENTÃO num6 < num6 + 1 

FIM 
ESCREVA “O número 
ESCREVA “O número 
ESCREVA “O número 
ESCREVA “O número 
ESCREVA “O número 
ESCREVA “O número 
FIM_ALGORITMO. 


foi sorteado “, numl, “vez(es)” 
foi sorteado “”, num2, “vez(es)” 
foi sorteado “, num3, “vez(es)” 
foi sorteado “, num4, “vez(es)” 
foi sorteado “”, num5, “vez(es)” 


SS UM ab UNBE 


foi sorteado “”, num6, “vez(es)” 


PASCAL SOLUÇÃO: 
E \EXERC\CAP6\PASCAL\EX18.PAS e VEXERCICAP6PASCALNEX18.EXE 


VLt Ra SoLução: 
D \EXERC\CAP6\C++\EX18.CPP e \EXERC\CAP6\C++\EX18.EXE 


BAIANO SOLUÇÃO: 
EEE \EXERC\CAP6\JAVA\EX18.java e NEXERCICAP6JAVANEX18.class 


ELJ Faça um programa que preencha dois vetores, A e B, com vinte caracteres cada. A seguir, troque o 1º 
elemento de À com o 20º de B, o 2º de A com o 19º de B, e assim por diante, até trocar o 20º de A com 
o 1º de B. Mostre os vetores antes e depois da troca. 


Vetor 1 — Antes da troca 
AG YIWI| 5 V S 8 6 J GIAIWI|2IM|C|H/Q]6 L 
1 2 5 4 5 6 F 8 12 13 14 15 16 17 18 19 20 


[to 
o 


Vetor 2 — Antes da troca 
S D| 4 5 HG R] U 8 9 K S A 1 2 V 4 D 5M 
1 2 3 4 5 6 Fá 12 13 14 15 16 17 18 19 20 


(to 
o 
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Vetor 1 — Depois da troca 
M|5/D] 4 /V|2 1 AJS 
1 2 3 4 5 6 7 8 9 


Vetor 2 — Depois da troca 
LI6GIQIHICIM|2 IWIA 
1 23 ES 4 5 6 7 8 9 


EELER ITIMO) Solução: 


ALGORITMO 
DECLARE vet1[20], vet2[20] LITERAL 
aux LITERAL 
i, j NUMÉRICO 
PARA i — 1 ATÉ 20 FAÇA 
INÍCIO 
LEIA vetl[i] 
FIM 
PARA i — 1 ATÉ 20 FAÇA 
INÍCIO 
LEIA vet2[i] 
FIM 
PARA i — 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA vetl[i] 
FIM 
PARA i — 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA vet2[i] 
FIM 
j — 20 
PARA i — 1 ATÉ 20 FAÇA 
INÍCIO 
aux — vetl[i] 
vetl[i] — vet2[5] 
vet2[j] — aux 


ah Ram ap dE 
FIM 
PARA i < 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA vetl[i] 
FIM 
PARA i — 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA vet2[i] 
FIM 


FIM ALGORITMO. 


PASCAL [SioRtoiton 
E VEXERCACAP6NPASCALVEX19.PAS e VEXERCICAP6NPASCALNEX19.EXE 


C/C++ Sorução: 


Co \EXERC\CAP6\C++\EX19.CPP e \EXERC\CAP6\C++\EX19.EXE 


E-Go- SoLução: 


K 19 
10 11 
G |] 
10 11 


8 
12 


6 
12 


U 
15 


8 
13 


R 
14 


S 
14 


G 
15 


V 
15 


H 
16 


5 
16 


5 
17 


W 
17 


cD \EXERC\CAP6\JAVA\EX19.java e \EXERC\CAP6\JAVA\EX19.class 


4 
18 


Y. 
18 


DIS 
19 20 


GIA 
19 20 
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PIN Faça um programa que leia um vetor com cinco posições para números reais e, depois, um código 
inteiro. Se o código for zero, finalize o programa; se for 1, mostre o vetor na ordem direta; se for 2, 
mostre o vetor na ordem inversa. 


(AILTSIOJRN TTIMO) Solução: 


ALGORITMO 
DECLARE vet [5], i, cod NUMÉRICO 
PARA i < 1 ATÉ 5 FAÇA 


INÍCIO 
LEIA vet[i] 
FIM 
LEIA cod 
SE cod = 0 
ENTÃO ESCREVA “fim” 
SE cod = 1 


ENTÃO INÍCIO 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
ESCREVA vet[i] 
FIM 
FIM 
SE cod = 2 
ENTÃO INÍCIO 
PARA i <— 5 ATÉ 1 PASSO - 1 FAÇA 
INÍCIO 
ESCREVA vet[i] 
FIM 
FIM 
SE (cod < 0) OU (cod > 2) 
ENTÃO ESCREVA “Código inválido” 
FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
GRE VEXERCACAP6NPASCALVEX20.PAS e NEXERCACAP6NPASCALNEX20.EXE 


oPAeR Ra SoLução: 
GER \EXERC\CAP6\C++\EX20.CPP e NEXERCACAP6NC++NEX20. EXE 


BAIANO SOLUÇÃO: 
D \EXERC\CAP6\JAVA\EX20.java e \EXERC\CAP6\JAVA\EX20.class 


FE Faça um programa que leia um conjunto de quinze valores e armazene-os em um vetor. A seguir, sepa- 
re-os em dois outros vetores (P e I) com cinco posições cada. O vetor P armazena números pares e o 
vetor I, números ímpares. Como o tamanho dos vetores pode não ser suficiente para armazenar todos 
os números, deve-se sempre verificar se já estão cheios. Caso P ou I estejam cheios, deve-se mostrá-los 
e recomeçar o preenchimento da primeira posição. Terminado o processamento, mostre o conteúdo 
restante dentro dos vetores P e I. 


(AJLIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE vet[15], p[5], i[5] NUMÉRICO 
cont, k, poslivre p, poslivre i NUMÉRICO 
PARA cont + 1 ATÉ 15 FAÇA 
INÍCIO 
LEIA vet[cont] 
FIM 
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poslivre p — 1 
poslivre i < 1 
PARA cont + 1 ATÉ 15 FAÇA 
INÍCIO 
SE RESTO(vet[cont]/2) = 0 
ENTÃO INÍCIO 
p[poslivre p] — vet[cont] 
poslivre p — poslivre p + 1 
FIM 
SENÃO INÍCIO 
i[lposlivre i] — vet[cont] 
poslivre i « poslivre i + 1 
FIM 
SE poslivre p = 6 
ENTÃO INÍCIO 
ESCREVA “Vetor de pares cheio” 
PARA k — 1 ATÉ (poslivre p — 1) FAÇA 


INÍCIO 

ESCREVA p[k] 

FIM 
poslivre p — 1 


FIM 
SE poslivre i = 6 
ENTÃO INÍCIO 
ESCREVA “Vetor de ímpares cheio” 
PARA k — 1 ATÉ (poslivre i — 1) FAÇA 
INÍCIO 
ESCREVA i[k] 
FIM 
poslivre i — 1 
FIM 
FIM 
SE poslivre p = 1 
ENTÃO INÍCIO 
ESCREVA “Vetor de pares restante” 
PARA k — 1 ATÉ (poslivre p — 1) FAÇA 
INÍCIO 
ESCREVA p[k] 
FIM 
FIM 
SE poslivre i * 1 
ENTÃO INÍCIO 
ESCREVA “Vetor de ímpares restante” 
PARA k — 1 ATÉ (poslivre i — 1) FAÇA 
INÍCIO 
ESCREVA i[k] 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
VEXERCACAP6NPASCALNVEX21.PAS e NEXERCICAP6NPASCALNEX21.EXE 


VETA SoLução: 
\EXERC\CAP6\C++\EX21.CPP e \EXERC\CAP6\C++\EX21.EXE 


RANMA SoLução: 
\EXERC\CAP6\JAVA\EX21.java e NEXERCICAP6JAVANEX21.class 
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EFA Faça um programa que simule um controle bancário. Para tanto, devem ser lidos os códigos de dez 
contas e seus respectivos saldos. Os códigos devem ser armazenados em um vetor de números inteiros 
(não pode haver mais de uma conta com o mesmo código) e os saldos devem ser armazenados em um 
vetor de números reais. O saldo deverá ser cadastrado na mesma posição do código. Por exemplo, se 
a conta 504 foi armazenada na quinta posição do vetor de códigos, seu saldo deverá ficar na quinta 
posição do vetor de saldos. Depois de fazer a leitura dos valores, deverá aparecer o seguinte menu na 
tela: 
1. Ffetuar depósito 
2. Efetuar saque 
3. Consultar o ativo bancário, ou seja, o somatório dos saldos de todos os clientes 


4. Finalizar o programa 
para efetuar depósito, deve-se solicitar o código da conta e o valor a ser depositado. Se a conta não 
estiver cadastrada, deverá aparecer a mensagem Conta não encontrada e voltar ao menu. Se a conta 
existir, atualizar seu saldo; 


para efetuar saque, deve-se solicitar o código da conta e o valor a ser sacado. Se a conta não esti- 
ver cadastrada, deverá aparecer a mensagem Conta não encontrada e voltar ao menu. Se a conta 
existir, verificar se o seu saldo é suficiente para cobrir o saque. (Estamos supondo que a conta não 
possa ficar com o saldo negativo.) Se o saldo for suficiente, realizar o saque e voltar ao menu. Caso 
contrário, mostrar a mensagem Saldo insuficiente e voltar ao menu; 


para consultar o ativo bancário, deve-se somar o saldo de todas as contas do banco. Depois de 
mostrar esse valor, voltar ao menu; 


o programa só termina quando for digitada a opção 4 — Finalizar o programa. 
(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE conta[10], saldo[10] NUMÉRICO 
i, j, codigo, valor, soma, op NUMÉRICO 
achou LÓGICO 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
achou + falso 
REPITA 
LEIA conta[i] 
PARA j < 1 ATÉ (i-l) FAÇA 


INÍCIO 

SE conta[i] = conta[5] 
ENTÃO achou + verdadeiro 
FIM 


ATÉ achou = falso 
LEIA saldo[i] 
FIM 
REPITA 
LEIA op 
achou + falso 
SE op = 1 
ENTÃO INÍCIO 
LEIA codigo, valor 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
SE codigo = conta[i] 
ENTÃO INÍCIO 
saldo[i] + saldo[i] + valor 
achou <— verdadeiro 
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ESCREVA “Depósito efetuado” 
FIM 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Conta não cadastrada” 


SE op = 2 
ENTÃO INÍCIO 
LEIA codigo, valor 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
SE codigo = conta[i] 
ENTÃO INÍCIO 
SE saldo[i] < valor 
ENTÃO INÍCIO 
ESCREVA “Saldo insuficiente” 
FIM 
SENÃO INÍCIO 
saldo[i] — saldo[i] - valor 
ESCREVA “Saque efetuado” 
FIM 
achou + verdadeiro 
FIM 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Conta não cadastrada” 


SE op = 3 
ENTÃO INÍCIO 
soma — 0 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
soma <— soma + saldo[i] 
FIM 
ESCREVA soma 
FIM 
SE (op < 1) OU (op > 4) 
ENTÃO ESCREVA “Opção inválida” 
ATÉ op = 4 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
VEXERCACAP6NPASCALVEX22.PAS e VEXERCÍCAP6NPASCALNEX22.EXE 


Gs 
C/C++ Sorução: 
D \EXERC\CAP6\C++\EX22.CPP e \EXERC\CAP6\C++\EX22. EXE 


E-G- SoLução: 
Eae \EXERC\CAP6\JAVA\EX22.java e \EXERC\CAP6\C++\JAVA\EX22.class 


FER Uma empresa possui ônibus com 48 lugares (24 nas janelas e 24 no corredor). Faça um programa que 
utilize dois vetores para controlar as poltronas ocupadas no corredor e na janela. Considere que O 
representa poltrona desocupada e 1, poltrona ocupada. 


Janela | O 1 0 0 = | 1 0 0 


Corredor 0 (0) 0 1 n 1 (0) (0) 
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Inicialmente, todas as poltronas estarão livres. Depois disso, o programa deverá apresentar as seguintes 
opções: 


vender passagem; 


mostrar mapa de ocupação do ônibus; 
encerrar. 


Quando a opção escolhida for Vender Passagem, deverá ser perguntado se o usuário deseja janela ou 
corredor e o número da poltrona. O programa deverá, então, dar uma das seguintes mensagens: 


Venda efetivada — se a poltrona solicitada estiver livre, marcando-a como ocupada. 
Poltrona ocupada — se a poltrona solicitada não estiver disponível para venda. 
Ônibus lotado — quando todas as poltronas já estiverem ocupadas. 


Quando a opção escolhida for Mostrar Mapa de Ocupação do Ônibus, deverá ser mostrada uma lis- 
tagem conforme a seguir: 


JANELA CORREDOR 
1- Ocupada 1- Ocupada 
2- Ocupada 2- Livre 
3- Livre 3- Livre 
4- Livre 4- Ocupada 
5- Ocupada 5- Livre 


Quando for escolhida a opção Encerrar, a execução do programa deverá ser finalizada. 
(AILIGIOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE corredor[24], janela[24] NUMÉRICO 
achou LÓGICO 
posicao LITERAL 
i, num NUMÉRICO 
PARA i — 1 ATÉ 24 FAÇA 
INÍCIO 
corredor[i] — 0 
janela[i] — 0 
FIM 
REPITA 
ESCREVA “1- Vender passagem” 
ESCREVA “2- Mostrar mapa de ocupação do ônibus” 
ESCREVA “3- Encerrar” 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
achou + falso 
PARA i — 1 ATÉ 24 FAÇA 
INÍCIO 
SE corredor[i] = 0 OU janela[i] = 0 
ENTÃO achou «< verdadeiro 
FIM 
SE achou = falso 
ENTÃO ESCREVA “Ônibus lotado” 
SENÃO INÍCIO 
REPITA 
LEIA posicao 
ATÉ posicao = “J” OU posicao = “C” 
REPITA 
LEIA num 
ATÉ num >= 1 E num <= 24 
SE posicao = “J” E janela[num] = 1 
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ENTÃO ESCREVA “Poltrona ocupada” 
SENÃO INÍCIO 
ESCREVA “Venda efetivada” 
janela[num] — 1 
FIM 
SE posicao = “C” E corredor [num] = 1 
ENTÃO ESCREVA “Poltrona ocupada” 
SENÃO INÍCIO 
ESCREVA “Venda efetivada” 
corredor [num] — 1 
FIM 
FIM 


SE op = 2 

ENTÃO INÍCIO 
ESCREVA “JANELA CORREDOR” 
PARA i — 1 ATÉ 24 FAÇA 


INÍCIO 
SE janela[i] = 0 
ENTÃO ESCREVA i, “- Livre” 
SENÃO ESCREVA i, “- Ocupada” 
SE corredor[i] = 0 
ENTÃO ESCREVA i, “- Livre” 
SENÃO ESCREVA i, “- Ocupada” 
FIM 
FIM 
ATÉ op = 3 


FIM ALGORITMO. 


PASCAL SOLUÇÃO: 

D \EXERC\CAP6\PASCAL\EX23.PAS e \EXERC\CAP6\PASCAL\EX23.EXE 
C/C++ E 

D \EXERC\CAP6\C++\EX23.CPP e \EXERC\CAP6\C++\EX23. EXE 


REGIS SoLução: 
D \EXERC\CAP6\JAVA\EX23.java e \EXERC\CAP6\JAVA\EX23.class 


EZY Faça um programa que leia um vetor A de dez posições contendo números inteiros. Determine e mostre, 
a seguir, quais elementos de À estão repetidos e quantas vezes cada um se repete. 


Vetor A | 5 4 3 18 5 5 4 | 
1 


18 4 18 
9 10 


Caso sejam digitados valores como os apresentados no vetor A, o programa deverá mostrar ao final as 
seguintes informações: 


o número 5 aparece 2 vezes; 
o número 4 aparece 3 vezes; 
o número 3 aparece 2 vezes; 
o número 18 aparece 3 vezes. 
SoLUÇÃO: 
ALGORITMO 


DECLARE a[10], repetidos[10], vezes[10] NUMÉRICO 
i, j, qtde, cont, cont r NUMÉRICO 
PARA i <— 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA a[i] 
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FIM 
(fone Je <= dl 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
qtde — 1 
PARA j — 1 ATÉ 10 FAÇA 
INÍCIO 
SE 1 £ j 
ENTÃO SE a[i] = a[j] 
ENTÃO qtde — qtde + 1 
FIM 
SE qtde > 1 
ENTÃO INÍCIO 
cont — 1 
ENQUANTO (cont < cont r E (a[i]l # repetidos[cont])) FAÇA 
INÍCIO 
cont <— cont + 1 
FIM 
SE cont = cont r 
ENTÃO INÍCIO 
repetidos[cont r] <— a[i] 
vezes[cont r] < qtde 
contr COntin a 


FIM 
FIM 
FIM 
PARA i < 1 ATÉ cont_r - 1 FAÇA 
ESCREVA “O número “,repetidos[il], “ apareceu “,vezes[i],” vezes” 


FIM ALGORITMO. 


PASCAL EOLO 
D \EXERC\CAP6\PASCAL\EX24.PAS e \EXERC\CAP6\PASCAL\EX24.EXE 


C/c++ Solução: 
inss \EXERC\CAP6\C++\EX24.CPP e NEXERCACAP6NC++HNEX24. EXE 


RB WIANA SoLução: 
iss VEXERCICAP6JAVANEX24. java e NEXERCICAP6JAVANEX24.class 


FER Faça um programa que gere os dez primeiros números primos acima de 100 e armazene-os em um 
vetor. Escreva no final o vetor resultante. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE primos[10] NUMÉRICO 
i, qtde, num, divisores NUMÉRICO 
num — 101 
qtde — 1 
REPITA 
divisores — 0 
PARA i — 1 ATÉ num FAÇA 
INÍCIO 
SE RESTO(num/i) = 0 
ENTÃO divisores <— divisores + 1 
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FIM 
SE divisores <= 2 
ENTÃO INÍCIO 
primos [qtde] + num 
qtde — qtde + 1 
FIM 
num — num + 1 
ATÉ qtde = 11 
PARA i <— 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA primos [i] 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
EEN NEXERCACAP6NPASCALVEX25.PAS e VEXERCICAP6NPASCALNEX25.EXE 


VETA Solução: 
Ee \EXERC\CAP6\C++\EX25.CPP e NEXERCACAP6NC++NEX25. EXE 


JAVA E SoLuçÃo: 
E \EXERC\CAP6\JAVA\EX25.JAVA e VEXERCACAP6JAVANEX25.class 


EXERCÍCIOS PROPOSTOS 


BEER Faça um programa que preencha um vetor com seis elementos numéricos inteiros. Calcule e mostre: 
todos os números pares; 
a quantidade de números pares; 
todos os números ímpares; 
a quantidade de números ímpares. 
IFA Faça um programa que preencha um vetor com sete números inteiros, calcule e mostre: 
os números múltiplos de 2; 
os números múltiplos de 3; 
os números múltiplos de 2 e de 3. 
IEJ Faça um programa para controlar o estoque de mercadorias de uma empresa. Inicialmente, o programa de- 
verá preencher dois vetores com dez posições cada, onde o primeiro corresponde ao código do produto e o 
segundo, ao total desse produto em estoque. Logo após, o programa deverá ler um conjunto indeterminado 


de dados contendo o código de um cliente e o código do produto que ele deseja comprar, juntamente com a 
quantidade. Código do cliente igual a zero indica fim do programa. O programa deverá verificar: 


se o código do produto solicitado existe. Se existir, tentar atender ao pedido; caso contrário, exibir 
mensagem Código inexistente; 


cada pedido feito por um cliente só pode ser atendido integralmente. Caso isso não seja possível, 
escrever a mensagem Não temos estoque suficiente dessa mercadoria. Se puder atendê-lo, escrever 
a mensagem Pedido atendido. Obrigado e volte sempre; 


efetuar a atualização do estoque somente se o pedido for atendido integralmente; 
no final do programa, escrever os códigos dos produtos com seus respectivos estoques já atualizados. 
EA Faça um programa que preencha um vetor com quinze elementos inteiros e verifique a existência de elementos 
iguais a 30, mostrando as posições em que apareceram. 
BEM Uma escola deseja saber se existem alunos cursando, simultaneamente, as disciplinas Lógica e Linguagem de 
Programação. Coloque os números das matrículas dos alunos que cursam Lógica em um vetor, quinze alunos. 
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Coloque os números das matrículas dos alunos que cursam Linguagem de Programação em outro vetor, dez 
alunos. Mostre o número das matrículas que aparecem nos dois vetores. 

WA Faça um programa que receba o total das vendas de cada vendedor de uma loja e armazene-as em um vetor. 
Receba também o percentual de comissão a que cada vendedor tem direito e armazene-os em outro vetor. 
Receba os nomes desses vendedores e armazene-os em um terceiro vetor. Existem apenas dez vendedores na 
loja. Calcule e mostre: 


um relatório com os nomes dos vendedores e os valores a receber referentes à comissão; 
o total das vendas de todos os vendedores; 

o maior valor a receber e o nome de quem o receberá; 

o menor valor a receber e o nome de quem o receberá. 


IEA Faça um programa que preencha um vetor com dez números reais, calcule e mostre a quantidade de números 
negativos e a soma dos números positivos desse vetor. 


REA Faça um programa que preencha um vetor com os nomes de sete alunos e carregue outro vetor com a média 
final desses alunos. Calcule e mostre: 


o nome do aluno com maior média (desconsiderar empates); 


para cada aluno não aprovado, isto é, com média menor que 7, mostrar quanto esse aluno precisa ti- 
rar na prova de exame final para ser aprovado. Considerar que a média para aprovação no exame é 5. 
REA Faça um programa que preencha três vetores com dez posições cada um: o primeiro vetor, com os nomes de 
dez produtos; o segundo vetor, com os códigos dos dez produtos; e o terceiro vetor, com os preços dos pro- 
dutos. Mostre um relatório apenas com o nome, o código, o preço e o novo preço dos produtos que sofrerão 
aumento. 
Sabe-se que os produtos que sofrerão aumento são aqueles que possuem código par ou preço superior a 
R$ 1.000,00. Sabe-se ainda que, para os produtos que satisfazem as duas condições anteriores, código e 
preço, o aumento será de 20%; para aqueles que satisfazem apenas a condição de código, o aumento será 
de 15%; e para aqueles que satisfazem apenas a condição de preço, o aumento será de 10%. 


ELA Faça um programa que preencha um vetor com dez números inteiros e um segundo vetor com cinco nú- 
meros inteiros, calcule e mostre dois vetores resultantes. O primeiro vetor resultante será composto pela 
soma de cada número par do primeiro vetor somado a todos os números do segundo vetor. O segundo 
vetor resultante será composto pela quantidade de divisores que cada número ímpar do primeiro vetor 
tem no segundo vetor. 


Primeiro 
7 5 8 2 15 9 6 10 11 
vetor 
1 2 3 4 5 6 FA 8 9 10 
Segundo 
4 5 8 2 
vetor 
1 2 3 4 5 
Primeiro vetor resultante Segundo vetor resultante 


8+3+4+5+8+2 7 não possui 


divisores 
26 30 24 sê 0 1 2 
4+3+4+5+3+22 5 é divisível 15 é divisível 


apenas por 5 por 3 e por 5 
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EEE Faça um programa que receba dez números inteiros e armazene-os em um vetor. Calcule e mostre dois 
vetores resultantes: o primeiro com os números pares e o segundo, com os números ímpares. 


EPA Faça um programa que receba cinco números e mostre a saída a seguir: 


Digite o 1º número 5 
Digite o 2º número 3 
Digite o 3º número 2 
Digite o 4º número 0 


Digite o 5º número 2 
Os números digitados foram: 5 +3+2+0+ 2 =12 


EEA Faça um programa que receba o nome e a nota de oito alunos e mostre o relatório a seguir: 


Digite o nome do 1º aluno: Carlos 
Digite a nota do Carlos: 8 

Digite o nome do 2º aluno: Pedro 
Digite a nota do Pedro: 5 
Relatórios de notas 

Carlos 8.0 

Pedro 5.0 


Média da classe = ?? 
ELA Faça um programa que receba o nome e duas notas de seis alunos e mostre o relatório a seguir. Relatório 
de notas: 


ALUNO 12 PROVA 22 PROVA MÉDIA SITUAÇÃO 
Carlos 8,0 9,0 8,5 Aprovado 
Pedro 4,0 5,0 45 Reprovado 


média da classe = ? 

percentual de alunos aprovados = 2% 
percentual de alunos de exame = 2% 
percentual de alunos reprovados = 2% 


E Faça um programa que receba o nome de oito clientes e armazene-os em um vetor. Em um segundo vetor, 
armazene a quantidade de DVDs locados em 2011 por cada um dos oito clientes. Sabe-se que, para cada 
dez locações, o cliente tem direito a uma locação grátis. Faça um programa que mostre o nome de todos 
os clientes, com a quantidade de locações grátis a que ele tem direito. 


HA Faça um programa que receba o nome de cinco produtos e seus respectivos preços. Calcule e mostre: 
a quantidade de produtos com preço inferior a R$ 50,00; 
o nome dos produtos com preço entre R$ 50,00 e R$ 100,00; 
a média dos preços dos produtos com preço superior a R$ 100,00. 


EFA Faça um programa que preencha dois vetores de dez posições cada, determine e mostre um terceiro con- 
tendo os elementos dos dois vetores anteriores ordenados de maneira decrescente. 


EEA Faça um programa que preencha um vetor com quinze números, determine e mostre: 
o maior número e a posição por ele ocupada no vetor; 
o menor número e a posição por ele ocupada no vetor. 


BEER Faça um programa que leia dois vetores de dez posições e faça a multiplicação dos elementos de mesmo 
índice, colocando o resultado em um terceiro vetor. Mostre o vetor resultante. 
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EIA Faça um programa que leia um vetor com dez posições para números inteiros e mostre somente os nú- 
meros positivos. 


PXB Faça um programa que leia um vetor com dez posições para números inteiros. Crie um segundo vetor, 
substituindo os valores nulos por 1. Mostre os dois vetores. 


EFA Faça um programa que leia um vetor A de dez posições. Em seguida, compacte o vetor, retirando os 
valores nulos e negativos. Armazene esse resultado no vetor B. Mostre o vetor B. (Lembre-se: o vetor B 
pode não ser completamente preenchido.) 


FF Faça um programa que leia dois vetores (A e B) com cinco posições para números inteiros. O programa 
deve, então, subtrair o primeiro elemento de A do último de B, acumulando o valor, subtrair o segundo 
elemento de A do penúltimo de B, acumulando o valor e assim por diante. Ao final, mostre o resultado 
de todas as subtrações realizadas. 


EZH Faça um programa que leia um vetor com quinze posições para números inteiros. Crie, a seguir, um vetor 
resultante que contenha todos os números primos do vetor digitado. Escreva o vetor resultante. 


FER Faça um programa que leia um vetor com quinze posições para números inteiros. Depois da leitura, di- 
vida todos os seus elementos pelo maior valor do vetor. Mostre o vetor após os cálculos. 


CAPÍTULO 


7.1 Matriz em algoritmos 


7.1.1 Definição de matriz 


Uma matriz é uma variável composta homogênea multidimensional. Ela é formada por uma sequência 
de variáveis, todas do mesmo tipo, com o mesmo identificador (mesmo nome), e alocadas sequencialmente 
na memória. Uma vez que as variáveis têm o mesmo nome, o que as distingue são índices que referenciam 
sua localização dentro da estrutura. Uma variável do tipo matriz precisa de um índice para cada uma de 
suas dimensões. 


7.1.2 Declaração de matriz 
Um algoritmo pode declarar uma matriz, conforme descrito a seguir. 


DECLARE nome[dimensãol, dimensão2, dimensão3, ..., dimensãoN] tipo 


onde: 

nome: é o nome da variável do tipo matriz; 

dimensão1: é a quantidade de elementos da 1 dimensão (muitas vezes, chamada linha); 
dimensão2: é a quantidade de elementos da 2: dimensão (muitas vezes, denominada coluna); 
dimensão3: é a quantidade de elementos da 32 dimensão (muitas vezes, chamada profundidade); 
dimensãoN: é a quantidade de elementos da enésima dimensão; 

tipo: é o tipo de dados dos elementos da matriz. 


7.1.3 Exemplos de matriz 


O exemplo a seguir define uma matriz bidimensional, onde o tamanho da 1º dimensão (linha) é 3 e o 
da 2º dimensão (coluna) é 5. 


DECLARE X[3,5] NUMÉRICO 


\ 


sal 
3 \ 


IN x[1,1] x[3,4] 


O exemplo que se segue define uma matriz tridimensional, onde o tamanho da 1? dimensão (linha) é 4; 
o da 2º dimensão (coluna), 6; e o da 3: dimensão (profundidade), 3. 


DECLARE X[4,6,3] NUMÉRICO 
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pe E 


1 2 3 4 5 6 


X[3,6,2] 


7.1.4 Atribuindo valores a uma matriz 


Cada elemento de uma matriz pode armazenar um valor. Para fazer esse armazenamento, é necessário 
executar uma atribuição, informando o número da posição desejada em cada dimensão. 


Exemplo 1: 


declare mat [5,4] numérico 
mat[2,4] — 45 
mat[3,1] — -8 
mat[1,3] — 10 


No exemplo 1, a declaração da matriz mat informa que ela tem 2 dimensões. A primeira dimensão, 
que representa as linhas, tem tamanho 5; a segunda dimensão de mat tem tamanho 4. Ou seja, para cada 
linha há 4 colunas, permitindo, assim, que a matriz tenha espaço para armazenar 20 valores numéricos. A 
representação gráfica da matriz mat e as três atribuições podem ser vistas a seguir. 


1 10 
2 45 
Matriz mat 3 -8 
4 
5 
1 2 3 4 


Exemplo 2: 


declare m[4,5,3] literal 
m[3,4,1] < “E” 
tds) => Meu 
m[1,2,2] — “A” 


No exemplo 2, a declaração da matriz m informa que ela tem 3 dimensões. A primera dimensão, que 
representa as linhas, tem tamanho 4; a segunda dimensão, que representa as colunas, tem tamanho 5; e a 
terceira dimensão, que representa a profundidade, tem tamanho 3. Assim, a matriz m tem espaço para arma- 
zenar 60 valores literais. A representação gráfica da matriz m e as três atribuições podem ser vistas a seguir. 
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1 2 3 4 5 
3 
2 A 
1 

Matriz m 1 

2 

g 
3 E 
4 


7.1.5 Preenchendo uma matriz 


Para preencher uma matriz é necessário identificar todas as suas posições. Isso exige a utilização de um 


índice para cada uma de suas dimensões. 


No exemplo a seguir, é mostrada uma matriz bidimensional com três linhas e cinco colunas. Observe 
que os valores assumidos pela variável i estão dentro do intervalo de 1 a 3, ou seja, exatamente o número 
das linhas da matriz. Por essa razão, a variável i é utilizada para indicar a primeira dimensão, dentro dos 
colchetes. Para cada valor assumido por i, a variável j assume os valores no intervalo de 1 a 5, ou seja, 
exatamente o número das colunas. Portanto, a variável 5 é utilizada para indicar a 2 dimensão, dentro dos 


colchetes. 


PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 


ESCREVA “Digite o número da linha “,i, “ e coluna: 


LEIA X[i,5] 
FIM 
FIM 


Simulação: 
MEMÓRIA 


1 1 Digi 
2 Digi 
3 Digi 
4 Digi 
5 Digi 
2 1 Digi 

2 Digi 

3 Digi 
4 Digi 
5 Digi 
3 Digi 
Digi 
3 Digi 
4 Digi 
5 Digi 


Assim, podemos imaginar os elementos dispostos em uma estrutura bidimensional, como uma tabela. 


e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 
e o nú 


e o nú 


e o nú 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


mero d 


TELA 


ha 1 e colu 
ha 1 e colu 
ha 1 e colu 
ha 1 e colu 
ha 1 e colu 
ha 2 e colu 
ha 2 e colu 
ha 2 e colu 
ha 2 e colu 
ha 2 e colu 
ha 3 e colu 
ha 3 e colu 
ha 3 e colu 
ha 3 e colu 


ha 3 e colu 


“ 


r 


j 
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1 2 3 4 5 

12 9 3 7 -23 
15 4 2 34 -4 
3 45 3 0 -3 


Já no exemplo que se segue, é preenchida uma matriz tridimensional com quatro linhas, três colunas 
e profundidade dois. Observe que os valores da variável i estão dentro do intervalo de 1 a 4, ou seja, 
exatamente o número das linhas da matriz. Para cada valor assumido por i, os valores da variável j se 
movimentam de 1 a 3, ou seja, as três colunas que cada linha possui. Por fim, os valores da variável k se 
alternam entre 1 e 2, exatamente os valores da profundidade. 


PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 


PARA j — 1 ATÉ 3 FAÇA 


INÍCIO 


PARA k — 1 ATÉ 2 FAÇA 
INÍCIO 
ESCREVA “Digite o número da linha “,i, 


FIM 
FIM 


Simulação: 


FIM 


ao 
LEIA X[i, j,k] 
MEMÓRIA 
i j 
1 1 
2 
3 
2 1 
2 
3 
3 1 
2 
3 
4 1 
2 
3 


gite o nú 


e o nú 


e o nú 


e o nú 


e o nú 


e o nú 


e o nú 


eo 


eo 


eo 


eo 


eo 


ite o 
ite o 
ite o 
ite o 
ite o 
ite o 
ite o 
ite o 
ite o 
ite o 


ite o 


nú 
nú 
nú 
nú 
nú 


nú 


número da li 
número da li 
número da li 
número da li 
número da li 
número da li 
número da li 
número da | 
número da li 


número da li 


gite o número da li 


mero da li 
mero da li 
mero da li 
mero da li 
mero da li 
mero da li 


mero da li 
mero da li 
mero da li 
mero da li 
mero da li 
mero da li 
mero da li 


n 
inha 4 colu 
n 


“ coluna 


TELA 


nha 1 colu 
nha 1 colu 
nha 1 colu 
nha 1 colu 
nha 1 colu 
nha 1 colu 
nha 2 colu 
nha 2 colu 
nha 2 colu 


nha 2 colu 
nha 2 colu 
nha 2 colu 
nha 3 colu 
nha 3 colu 
nha 3 colu 
nha 3 colu 
nha 3 colu 
nha 3 colu 
nha 4 colu 


nha 4 colu 
ha 4 colu 


ha 4 colu 


nha 4 colu 


na3e 
na3e 
nale 
nale 
na2e 
na2e 
na3e 
na3e 
nale 
nale 
na2e 


na2e 
na3e 
na3e 
nale 
nale 
na2e 
na2e 
na3e 


na3e 


na 1 e profundi 
na 1 e profundi 
na 2 e profundi 
na 2 e profundi 
profundi 
profundi 
profundi 
profundi 
profundi 


una 


una 


una 


una 


una 


olololololololo 


und 
ofund 


ofund 
ofund 
ofund 
ofund 


ofund 


undi 
undi 


“ 


r Jj, “ e profundidade 


:65 
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Assim, podemos imaginar os elementos dispostos em uma estrutura tridimensional, como um cubo. 


Matriz x 


7.1.6 Mostrando os elementos de uma matriz 


Para mostrar os elementos de uma matriz é preciso identificar suas posições. Como acontece com todas 
as operações realizadas com matrizes, é necessária a utilização de um índice para cada dimensão da matriz. 

No exemplo a seguir, uma matriz bidimensional com três linhas e cinco colunas é apresentada. Observe 
que a variável i assume valores sequenciais no intervalo de 1 a 3, ou seja, exatamente as linhas da matriz. 
Para cada valor assumido por i, a variável j assume valores sequenciais de 1 a 5, ou seja, as cinco colunas 
que cada linha possui. 


PARA i — 1 ATÉ 3 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
ESCREVA X[i,5] 
FIM 
FIM 


7.1.7 Percorrendo uma matriz 


Vimos anteriormente, nos tópicos 7.1.5 e 7.1.6, formas para preencher toda uma matriz e a fim de mos- 
trar todas as posições de uma matriz. Em tais operações, foi preciso passar por todas as posições da matriz, 
ou seja, foi necessário percorrer a matriz. 

Uma das formas mais simples de percorrer uma matriz pode ser por meio do uso de uma estrutura de 
repetição para cada dimensão da matriz. A disposição de tais estruturas de repetição define a forma como 
a matriz será percorrida. 

A seguir, apresentaremos duas formas para percorrer uma mesma matriz, chamada x, contendo 3 linhas 
e 4 colunas. 


1 4 5 1 10 

Matriz x 2 16 11 76 8 
3 9 54 32 89 

1 2 3 4 


Forma 1: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos gravados 
em cada linha. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a numera- 
ção à esquerda não faz parte do algoritmo, servirá apenas para facilitar a explicação). 


PARA i < 1 ATÉ 3 FAÇA 
INÍCIO 
ESCREVA “Elementos da linha “, i 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
ESCREVA x[i,5] 
FIM 
FIM 


o Ní A UM RUNE 
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A primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de 1 a 3. Cada vez que essa estrutura PARA for executada, encontrará a segunda estru- 
tura de repetição (linha 4), controlada pela variável j, que assumirá os valores dentro do intervalo de 1 a 4. 
Assim, cada valor assumido pela variável i estará associado a 4 valores da variável j. 

Esse arranjo resolve o problema de mostrar os elementos, separando-os por linhas, já que a variável i 
ficará com valor fixo, enquanto a variável j assumirá valores de 1 a 4, ou seja, formará todos os pares possí- 
veis de índices. Sei estiver valendo 1, serão mostrados todos os elementos da linha 1, já que serão formados 
os seguintes pares: x[1,1], x[1,2], x[1,3] e x[1,4]. Depois, a variável i assume o valor 2 e novamente a j terá 
seus valores variando de 1 a 4. Com isso, será possível percorrer toda a linha 2 por meio da formação dos 
pares x[2,1], x[2,2], x[2,3] e x[2,4]. Esse processo se repetirá para os demais valores possíveis de i. A tabela 
a seguir mostra uma simulação de execução do algoritmo. Nessa simulação, é importante observar como as 
variáveis i e j têm seus valores alterados. 


Simulação: 


MEMÓRIA TELA 


1 Elementos da linha 1 
1 1 4 

5 

1 

10 
Elementos da linha 2 

16 

11 

76 

8 
Elementos da linha 3 

9 

54 

32 

89 


BWIN 


BWIN a 


WOW WOW WNINTIN NINA 


ANIN 


A figura a seguir dá uma outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


1 4 5 1 10 
> p p pe -s 

Matriz x 2 16 ++ 76 8 
D a S S S E ++ 

3 9 -54 32 89 
p p L p p 

1 2 3 4 


Forma 2: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos gravados 
em cada coluna. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a nume- 
ração à esquerda não faz parte do algoritmo, servirá apenas para facilitar a explicação). 


PARA i —1 ATÉ 4 FAÇA 
INÍCIO 
ESCREVA “Elementos da coluna “, i 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
ESCREVA x[j, i] 
FIM 


ls 
2. 
3. 
4. 
5. 
6. 
7. 
8. FIM 


200 | Fundamentos da programação de computadores 


A primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de 1 a 4. Cada vez que essa estrutura PARA for executada, encontrará a segunda es- 
trutura de repetição (linha 4), controlada pela variável j, que assumirá os valores dentro do intervalo de 
1a 3. Assim, cada valor assumido pela variável i estará associado a 3 valores da variável j. Esse arranjo 
resolve o problema de mostrar os elementos, separando-os por colunas, já que a variável i ficará com valor 
fixo enquanto a variável j assumirá valores de 1 a 3, ou seja, formará todos os pares possíveis de índices. 
Se i estiver valendo 1, serão mostrados todos os elementos da coluna 1, já que serão formados os seguintes 
pares: x[1,1], x[2,1] e x[3,1]. Depois, a variável i assumirá o valor 2 e novamente j terá seus valores va- 
riando de 1 a 3. Com isso, será possível percorrer toda a coluna 2, por meio da formação dos pares x[1,2], 
x[2,2] e x[3,2]. Esse processo se repetirá para os demais valores possíveis de i. A tabela a seguir mostra 
uma simulação de execução do algoritmo. Nessa simulação é importante observar como as variáveis i e j 
têm seus valores alterados. 


Simulação: 
MEMÓRIA TELA 
i j 
1 Elementos da coluna 1 
1 1 4 
1 2 16 
1 9 
2 Elementos da coluna 2 
2 1 5 
2 2 11 
2 3 54 
3 Elementos da coluna 3 
3 1 1 
5 2 76 
3 5 32 
4 Elementos da coluna 4 
4 1 10 
4 2 8 
4 3 89 


A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


1 Ay y y 4 
Matriz x 2 14 ly 7 8 
4 2 8 
i ”4 i y $ y 4 
1 2 3 4 


Pelas formas de percorrer uma matriz, apresentadas anteriormente, podemos observar alguns pontos 
que merecem atenção: 


a mudança dos valores das varáveis i e j, que controlam as estruturas de repetição, permite a for- 
mação de todos os possíveis pares de linha e coluna existentes na matriz. 


a mudança do valor da variável i, utilizada no PARA externo, acontece mais lentamente que a mu- 
dança da variável j, utilizada no PARA interno. Logo, foi a variável i quem indicou como seria o 
percurso: na primeira forma apresentada, i variou de 1 a 3 e foi usada na primeira posição dentro 
do colchetes, isso mostrou que o percurso seria horizontal, porque o índice da linha ficava parado 
enquanto j assumia todas as colunas possíveis para aquela linha. Já na segunda forma apresentada, 
i variou de 1 a 4 e foi usada na segunda posição dentro dos colchetes, indicando que o percurso 
seria vertical, pois o índice da coluna ficava parado enquanto j assumia todas as linhas possíveis 
para aquela coluna. 
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7.2 Matriz em PASCAL 


7.21 Definição de matriz 


As variáveis compostas homogêneas multidimensionais (ou, simplesmente, matrizes) são conhecidas na 
linguagem PASCAL como ARRAY. Uma estrutura do tipo ARRAY é uma sequência de variáveis com o mesmo 
identificador (mesmo nome) e alocadas sequencialmente na memória. Todas as variáveis que compõem uma 
ARRAY devem ser do mesmo tipo. 

Uma vez que as variáveis recebem o mesmo nome, o que as distingue são os índices que referenciam sua 
posição em cada dimensão da estrutura. Assim, se a matriz for bidimensional necessitará de dois índices, se 
for tridimensional necessitará de três índices, e assim por diante. 


7.2.2 Declaração de matriz 


VAR nome da variável: ARRAY[iniciol..fiml, inicio2..fim2, 
inicioN..fimN] OF tipo dos dados; 
onde: 
nome da variável: é o nome da variável do tipo matriz; 
iniciol: é o índice inicial da primeira dimensão da matriz; 
fiml: é o índice final da primeira dimensão da matriz; 
início2: é o índice inicial da segunda dimensão da matriz; 
fim2: é o índice final da segunda dimensão da matriz; 
inicioN: é o índice inicial da n-ésima dimensão da matriz; 
fimN: é o índice final da n-ésima dimensão da matriz; 
tipo dos dados: é o tipo básico dos dados que serão armazenados na matriz. 


É importante salientar que o valor do índice inicial deve ser maior ou igual ao valor do índice fi- 
nal, para cada dimensão. As posições são identificadas com valores dentro desse intervalo. 

Além disso, é importante destacar que os índices também podem ser representados por valores alfa- 
béticos. Com isso, é permitido o uso de caracteres para representar o início e o fim de cada dimensão. O 
exemplo a seguir ilustra essa possibilidade. Como se pode ver, a matriz terá 5 linhas (de C a G) e 4 colunas 
(deLa O). 


VAR matriz: ARRAY ['C'..'G', 'L'..'O'] OF REAL; 


see Observação 


Os valores que indicam o índice inicial e o índice final devem representar valores 
fixos (literais! ou constantes), não podendo ser substituídos por variáveis. 


7.2.3 Exemplos de matriz 


VAR X: ARRAY[1..2,1..6] OF REAL; 


VAR MAT: ARRAY[2..5,3..6] OF CHAR; 


1 Literal é um valor fixo, definido quando se escreve o programa. Por exemplo: x:=10.3; onde 10.3 é um literal. vet: array 
[3..7, 4..9] of integer; onde 3,7, 4 e 9, escritos dentro dos colchetes, são literais. 
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MAT 


UU e Uù N 


VAR Y: ARRAY[1..2,1..4,1..3] OF REAL; 


VAR MAT: ARRAY['A'..'D', 'F'..'J'] OF INTEGER; 


MAT c 


CONST iniciol 
CONST fiml = 6; 

CONST inicio? = 8; 

CONST fim2 = 10; 

VAR MATRIZ: ARRAY [iniciol..fiml, inicio2..fim2] OF INTEGER; 


|| 
w 


MATRIZ 5 


72.4 Atribuindo valores a uma matriz 


Atribuir valor à matriz significa armazenar uma informação em um de seus elementos, identificado de 
forma única por meio de seus índices. 


Xx[1,4] := 5; — Atribui o valor 5 à posição identificada pelos índices 1 (linha) e 4 (coluna). 
1 2 3 4 5 6 
1 5 
X 
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MAT[4,5] :='D';  — Atribui a letra D à posição identificada pelos índices 4 (linha) e 5 (coluna). 


MAT 


a e U N 


Y[1,4,2] := 12; —> Atribui o valor 12 à posição identificada pelos índices 1 (linha), 4 (coluna) 
e 2 (profundidade). 
3 
ZZ 
y 1 
2 
1 2 3 4 
MAT['C','H'] := 20; — Atribui o valor 20 à posição identificada pelos índices C (linha) e H (coluna). 
A 
B 
MAT C 20 
D 
F G H I J 


7.2.5 Preenchendo uma matriz 


Preencher uma matriz significa percorrer todos os seus elementos, atribuindo-lhes um valor. Esse 


valor pode ser recebido do usuário, pelo teclado, ou pode ser gerado pelo programa. 


Exemplo 1: 
FOR i:= 1 TO 7 DO 
BEGIN 
FOR j:=1 TO 3 DO 
BEGIN 
READLN(X[i,5]); 
END; 
END; 
Exemplo 2: 
FOR i:='C' TO 'G' DO 
BEGIN 
FOR j:= 'L' TO '0' DO 
BEGIN 
READLN(MAT[i,5]); 
END; 


END; 
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O exemplo 1 apresentou duas estruturas de repetição FOR para garantir que a variável i assumisse to- 
dos os valores possíveis para linha (de 1 a 7) e a variável j assumisse todos os valores possíveis para coluna 
(de 1 a 3) da matriz x. Já o exemplo 2 utilizou duas estruturas de repetição FOR para garantir que a variável i 
assumisse todos os valores possíveis para linha (de Ca G) e a variável j assumisse todos os valores possíveis 
para coluna (de L a O) da matriz Mar. Assim, para cada execução das estruturas de repetição, uma posição 
diferente da matriz é preenchida com um valor digitado pelo usuário por meio do comando READLN. 


72.6 Mostrando os elementos de uma matriz 


Pode-se também percorrer todos os elementos da matriz, acessando seu conteúdo. Para mostrar os va- 
lores armazenados em uma matriz, veremos, a seguir, alguns trechos de programas. 


Exemplo 1: 


VAR X:ARRAY[1..10,1..6] OF REAL; 


FOR i:=1 TO 10 DO 


BEGIN 
FOR j:= 1 TO 6 DO 
BEGIN 
WRITELN(X[i,5]); 
END; 
END; 
Exemplo 2: 


VAR MAT:ARRAY['C..'G','L'..'O'] OF REAL; 


FOR i:='C' TO 'G' DO 


BEGIN 
FOR j:= ‘L’ TO ʻO' DO 
BEGIN 
WRITELN(MAT[i, j]); 
END; 
END; 


O exemplo 1 usou duas estruturas de repetição FOR para garantir que a variável i assumisse todos os 
valores possíveis para linha (de 1 a 10) e a variável j assumisse todos os valores possíveis para coluna (de 
1 a 6) da matriz x. Já o exemplo 2 utilizou duas estruturas de repetição FOR para garantir que a variável i 
assumisse todos os valores possíveis para linha (de Ca G) e a variável j assumisse todos os valores possíveis 
para coluna (de L a O) da matriz Mar. Assim, para cada execução das estruturas de repetição, uma posição 
diferente da matriz é acessada e seu valor mostrado por meio do comando WRITELN. 


7.2.7 Percorrendo uma matriz 


Vimos anteriormente, nos tópicos 7.2.5 e 7.2.6, formas para preencher toda uma matriz e para mostrar 
todas as posições de uma matriz. Em tais operações, foi necessário passar por todas as posições da matriz, 
ou seja, foi preciso percorrer a matriz. 

Uma das formas mais simples de percorrer uma matriz pode ser por meio do uso de uma estrutura de 
repetição para cada dimensão da matriz. A disposição de tais estruturas de repetição define a forma como 
a matriz será percorrida. 


A seguir, apresentaremos duas formas para percorrer uma mesma matriz, chamada x, contendo 3 linhas 
e 4 colunas. 
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1 4 5 1 10 

Matriz x 2 16 11 76 8 
3 9 54 32 89 

1 2 3 4 


Forma 1: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos 
gravados em cada linha. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a 
numeração à esquerda não faz parte do programa, servirá apenas para facilitar a explicação). 


1. FOR à := 1 TO 3 DO 

2. BEGIN 

So WRITELN( 'Elementos da linha ʻ, i); 
4. FOR j := 1 TO 4 DO 

o BEGIN 

6. WRITELN(x[1,)]); 

Ta END; 

8. END; 


A primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de 1 a 3. Cada execução da estrutura FOR encontrará a segunda estrutura de repetição 
(linha 4), controlada pela variável 5, que assumirá os valores dentro do intervalo de 1 a 4. Assim, cada valor 
assumido pela variável i estará associado a 4 valores da variável 5. 

Esse arranjo resolve o problema de mostrar os elementos, separando-os por linhas, já que a variável 
i ficará com valor fixo enquanto a variável j assumirá valores de 1 a 4, ou seja, formará todos os pares 
possíveis de índices. Se i estiver valendo 1, serão mostrados todos os elementos da primeira linha, já que 
serão formados os seguintes pares: x[1,1], x[1,2], x[1,3] e x[1,4]. Depois, a variável i assume o valor 2 e 
novamente a j terá seus valores variando de 1 a 4. Com isso, será possível percorrer toda a segunda linha, 
por meio da formação dos pares x[2,1], x[2,2], x[2,3] e x[2,4]. Esse processo se repetirá para os demais 
valores possíveis de i. A tabela a seguir mostra uma simulação de execução do programa. Nessa simulação 
é importante observar como as variáveis i e j têm seus valores alterados. 


Simulação: 


MEMÓRIA TELA 


1 Elementos da linha 1 
1 1 4 
2 5) 
1 3 1 
4 10 


Elementos da linha 2 
1 16 
2 1 
3 76 
4 8 
Elementos da linha 3 
1 9 
54 


WO WON NININININI NN 


2 
3 32 
4 89 
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A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


1 4 5 1 10 

p > p > 

Matriz x 2 d 16 tr a EE mE 
54 32 89 

3 4 e > > p 
1 2 3 4 


Forma 2: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos gra- 
vados em cada coluna. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a 
numeração à esquerda não faz parte do programa, servirá apenas para facilitar a explicação). 


1. FOR à := 1 TO 4 DO 

2. BEGIN 

3. WRITELN('Elementos da coluna ʻ, i); 
am FOR j := 1 TO 3 DO 

ja BEGIN 

6. WRITELN(x[j,1]); 

To END; 

8. END; 


A primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de 1 a 4. Cada execução da estrutura FOR encontrará a segunda estrutura de repetição 
(linha 4), controlada pela variável 5, que assumirá os valores dentro do intervalo de 1 a 3. Assim, cada va- 
lor assumido pela variável i estará associado a 3 valores da variável j. Esse arranjo resolve o problema de 
mostrar os elementos, separando-os por colunas, já que a variável i ficará com valor fixo enquanto a 
variável j assumirá valores de 1 a 3, ou seja, formará todos os pares possíveis de índices. Se i estiver va- 
lendo 1, serão mostrados todos os elementos da primeira coluna, já que serão formados os seguintes pares: 
x[1,1], x[2,1] e x[3,1]. Depois, a variável i assumirá o valor 2 e novamente j terá seus valores variando 
de 1 a 3. Com isso, será possível percorrer toda a segunda coluna, por meio da formação dos pares x[1,2], 
x[2,2] e x[3,2]. Esse processo se repetirá para os demais valores possíveis de i. A tabela a seguir mostra 
uma simulação de execução do programa. Nessa simulação, é importante observar como as variáveis i e 
3 têm seus valores alterados. 


Simulação: 


MEMÓRIA TELA 


1 Elementos da coluna 1 
1 1 4 

16 

9 
Elementos da coluna 2 


11 
54 
Elementos da coluna 3 
1 1 
76 
32 
Elementos da coluna 4 
1 10 
8 
89 


BB E E E UN NINININININJIN 
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A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


Matriz x 2 


1 2 3 4 
Pelas formas de percorrer uma matriz apresentadas anteriormente, podemos observar alguns pontos 
que merecem atenção: 
a mudança dos valores das varáveis i e j, que controlam as estruturas de repetição, permite a for- 
mação de todos os possíveis pares de linha e coluna existentes na matriz. 


a mudança do valor da variável i, utilizada no FOR externo, acontece mais lentamente que a 
mudança da variável 5, utilizada no FOR interno. Logo, foi a variável i que indicou como seria o 
percurso: na primeira forma apresentada, i variou de 1 a 3 e foi usada na primeira posição dentro 
do colchetes, isso mostrou que o percurso seria horizontal, porque o índice da linha ficava parado 
enquanto j assumia todas as colunas possíveis para aquela linha. Já na segunda forma apresenta- 
da, i variou de 1 a 4 e foi usada na segunda posição dentro dos colchetes, indicando que o percurso 
seria vertical, pois o índice da coluna ficava parado enquanto j assumia todas as linhas possíveis para 
aquela coluna. 


7.3 Matriz em C/C++ 


7.3.1 Definição de matriz 


Uma matriz pode ser definida como um conjunto de variáveis de mesmo tipo e identificadas pelo 
mesmo nome. Essas variáveis são diferenciadas por meio da especificação de suas posições dentro dessa 
estrutura. 

A linguagem C/C++ permite a declaração de matrizes unidimensionais (mais conhecidas como vetores — 
descritos no capítulo anterior), bidimensionais e multidimensionais. O padrão ANsI prevê até 12 dimensões. 
Entretanto, o limite de dimensões fica por conta da quantidade de recursos computacionais disponíveis. 
Apesar disso, as matrizes mais utilizadas possuem duas dimensões. Para cada dimensão deve ser utilizado 
um índice. 

Os índices usados na linguagem C/C++, para identificar as posições de uma matriz, começam sempre 
em 0 (zero) e vão até o tamanho da dimensão menos uma unidade. Os índices de uma matriz em C/C++ 
devem sempre ser representados por um dos tipos inteiros disponíveis na linguagem. 


7.3.2 Declaração de matriz 


tipo dos dados nome variável [dimensãol] [dimensão2] [...] [dimensãoN]; 


onde: 


tipo dos dados: é o tipo dos dados que serão armazenados na matriz; 
nome variável: é o nome dado à variável do tipo matriz; 
[dimensão1]: representa o tamanho da 1º dimensão da matriz; 
[dimensão2]: representa o tamanho da 2º dimensão da matriz; 
[dimensãoN]: representa o tamanho da n-ésima dimensão da matriz. 

Em C/C++, a indicação do tamanho das dimensões de uma matriz deve ser feita por um valor inteiro 
fixo (representado por um literal? ou uma constante). Se houver necessidade de definir o tamanho do ve- 
tor em tempo de execução, deve-se fazê-lo por meio de ponteiros (o Capítulo 8 apresentará o conceito de 
ponteiro). 


2 Literal é um valor fixo, definido quando se escreve o programa. Por exemplo: double x=10.3; onde 10.3 é um literal. char mat [2][5]; 
onde 2 e 5, escritos dentro dos colchetes, são literais. 
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7.3.3 Exemplos de matriz 


Da mesma maneira como ocorre com os vetores, os índices das dimensões das matrizes começam sem- 
pre em O (zero). 
À seguir, são apresentadas algumas formas de criação de matrizes. 


Exemplo 1: 
float X[2][6]; 


Na declaração do exemplo 1, criou-se uma variável chamada x contendo duas linhas (de O a 1) com seis 
colunas cada (de O a 5), capaz de armazenar números reais, como pode ser observado a seguir. 


Exemplo 2: 
char MAT [4][3]; 


A declaração do exemplo 2 criou uma variável chamada mar contendo quatro linhas (de O a 3) com três 
colunas cada (de O a 2), capaz de armazenar caracteres, como pode ser observado a seguir. 


MAT 1 


0 1 2 
op ll] 


Exemplo 3: 
float Y[2][4][3]; 


A declaração do exemplo 3 criou uma variável chamada Y contendo duas linhas (de O a 1) com quatro 
colunas cada (de O a 3) e profundidade três (de O a 2), capaz de armazenar números reais, como pode ser 


observado a seguir. 
1 
| 


7.3.4 Atribuindo valores a uma matriz 


Atribuir valor a uma matriz significa armazenar informação em seus elementos, identificados de forma 
única por meio de seus índices. 
X[1][4] = 5; — Atribui o valor 5 à posição identificada pelos índices 1 (22 linha) e 4 (5º coluna). 
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MAT[3][2] = ‘D’; — Atribui a letra D à posição identificada pelos índices 3 (42 linha) e 2 
(3º coluna). 
0 1 2 
2 
O 
2 f | 
3 o] | D 
Y[0][3][1] = 12; — Atribui o valor 12 à posição identificada pelos índices O (12 linha), 3 
(4º coluna) e 1 (2: profundidade). 
Y 2 
0 z 2 
12 | 
0 | | 
1 | 
0 1 2 3 


7.3.5 Preenchendo uma matriz 


Preencher uma matriz significa percorrer todos os seus elementos, atribuindo-lhes um valor. Esse valor 
pode ser recebido do usuário, por meio do teclado, ou pode ser gerado pelo programa. 

No exemplo que se segue, todos os elementos de uma matriz bidimensional são percorridos, atribuin- 
do-lhes valores digitados pelo usuário e capturados pelo comando scanf. 


for (i=0;i<7,i++) 
{ 
for (j=0;j<3; j++) 
scanf (“%d%*c", &MAT[i][j]); 
} 


Como a matriz possui 7 linhas e 3 colunas, o exemplo apresentou duas estruturas de repetição for para 
garantir que a variável i assumisse todos os valores possíveis para linha (de 0 a 6) e a variável j assumisse 
todos os valores possíveis para coluna (de O a 2) da matriz MaT. Assim, para cada execução das estruturas 
de repetição, uma posição diferente da matriz foi preenchida por um valor digitado pelo usuário por meio 
do comando scanf. 


7.3.6 Mostrando os elementos de uma matriz 


Pode-se também percorrer todos os elementos de uma matriz acessando seu conteúdo. Para mostrar os 
valores armazenados dentro de uma matriz, supondo que ela tenha sido declarada como float x[10][6], 
podem-se executar os comandos a seguir. 


for (i=0;i<1l0;i++) 
{ for (j=0;j<6;j++) 
printf (“%f”, X[i][j]l); 
} 


Como a matriz possui dez linhas e seis colunas, o exemplo usou duas estruturas de repetição for para 
garantir que a variável i assumisse todos os valores possíveis para linha (de 0 a 9) e a variável j assumisse 
todos os valores possíveis para coluna (de 0 a 5) da matriz x. Assim, para cada execução das estruturas de 
repetição, uma posição diferente da matriz foi acessada e seu conteúdo mostrado por meio do comando 
printf. 
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7.3.7 Percorrendo uma matriz 


Vimos anteriormente, nos tópicos 7.3.5 e 7.3.6, formas para preencher toda uma matriz e para mostrar 
todas as posições de uma matriz. Em tais operações, foi necessário passar por todas as posições, ou seja, foi 
preciso percorrer a matriz. 

Uma das formas mais simples de percorrer uma matriz pode ser por meio do uso de uma estrutura de 
repetição para cada dimensão da matriz. A disposição de tais estruturas de repetição define a forma como 
a matriz será percorrida. 

A seguir, apresentaremos duas formas para percorrer uma mesma matriz, chamada x, contendo 3 linhas 
e 4 colunas. 


0 4 5 1 10 

Matriz x 1 16 11 76 8 
2 9 54 32 89 

0 1 2 3 


Forma 1: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos 
gravados em cada linha. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a 
numeração à esquerda não faz parte do programa, servirá apenas para facilitar a explicação). 


1. for(i=0,i<3;i++) 

2. + 

3 printf(“Elementos da linha èd“, i); 
4. for(j=0;j<4; j++) 

Do { 

6 printf (“%d”", x[i,j]); 

7 J 

8. } 


A primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de 0 a 2. Cada execução da estrutura for encontrará a segunda estrutura de repetição 
(linha 4), controlada pela variável j, que assumirá os valores dentro do intervalo de 0 a 3. Assim, cada valor 
assumido pela variável i estará associado a 4 valores da variável j. 

Esse arranjo resolve o problema de mostrar os elementos, separando-os por linhas, já que a variável 
i ficará com valor fixo enquanto a variável j assumirá valores de 0 a 3, ou seja, formará todos os pares 
possíveis de índices. Se i estiver valendo 0, serão mostrados todos os elementos da primeira linha, já que 
serão formados os seguintes pares: x[0,0], x[0,1], x[0,2] e x[0,3]. Depois, a variável i assume o valor 1 e 
novamente a j terá seus valores variando de 0 a 3. Com isso, será possível percorrer toda a segunda linha, 
por meio da formação dos pares x[1,0], x[1,1], x[1,2] e x[1,3]. Esse processo se repetirá para os demais 
valores possíveis de i. A tabela a seguir mostra uma simulação de execução do programa. Nessa simulação 
é importante observar como as variáveis i e j têm seus valores alterados. 


Simulação: 
MEMÓRIA TELA 


Elementos da linha O 
(0) 4 

5 

1 

10 

1 Elementos da linha 1 
1 (0) 16 


O|/0/0/0]/0|+- 


Capítulo 7 Matriz | 211 


MEMÓRIA TELA 


Elementos da linha 2 
(0) 9 
54 
32 
89 


NINININI N|—= 


A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


0 4 5 1 10 
e p p Le = 

Matriz x 1 a 16 ++ 76 8 
> p pe Es r 

9 54- 32 89 
2 4 > > > p > 

0 1 2 3 


Forma 2: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos gra- 
vados em cada coluna. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a 
numeração à esquerda não faz parte do programa, servirá apenas para facilitar a explicação). 


1. for (i=0,i<4,i++) 

Zi 

So printf(“Elementos da coluna 3d”, i); 
4. for (j=0;j<3; j++) 

5. { 

6. printf(“Sd”, x[j, LIA 

To } 

8. + 


À primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de 0 a 3. Cada execução dessa estrutura for encontrará a segunda estrutura de repetição 
(linha 4), controlada pela variável 5, que assumirá os valores dentro do intervalo de O a 2. Assim, cada valor 
assumido pela variável i estará associado a 3 valores da variável j. Esse arranjo resolve o problema de mos- 
trar os elementos, separando-os por colunas, já que a variável i ficará com valor fixo enquanto a variável j 
assumirá valores de O a 2, ou seja, formará todos os pares possíveis de índices. Se i estiver valendo 0, serão 
mostrados todos os elementos da primeira coluna, já que serão formados os seguintes pares: x[0,0], x[1,0] 
e x[2,0]. Depois, a variável i assumirá o valor 1 e novamente j terá seus valores variando de O a 2. Com 
isso, será possível percorrer toda a segunda coluna, por meio da formação dos pares x[0,1], x[1,1] e x[2,1]. 
Esse processo se repetirá para os demais valores possíveis de i. A tabela a seguir mostra uma simulação de 
execução do programa. Nessa simulação, é importante observar como as variáveis i e j têm seus valores 
alterados. 


Elementos da coluna 1 
0 5 


Simulação: 
MEMÓRIA TELA 
i j 
0 Elementos da coluna O 
(0) (0) 4 
0 1 16 
0 2 9 
1 
1 
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MEMÓRIA TELA 

1 1 11 

1 2 54 

2 Elementos da coluna 2 
2 (0) 1 

2 1 76 

2 2 32 

3 Elementos da coluna 3 
3 (0) 10 

3 1 8 

3 2 89 


A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


o0 | ży y 
Matriz x 1 16 y 114 76 
2 9 54 32 
y y 
0 1 2 3 


Pelas formas de percorrer uma matriz apresentadas anteriormente, podemos observar alguns pontos 
que merecem atenção: 


a mudança dos valores das varáveis i e j, que controlam as estruturas de repetição, permite a for- 
mação de todos os possíveis pares de linha e coluna existentes na matriz. 


a mudança do valor da variável i, utilizada no for externo, acontece mais lentamente que a mudança 
da variável j, utilizada no for interno. Logo, foi a variável i que indicou como seria o percurso: na 
primeira forma apresentada, i variou de 0 a 2 e foi usada na primeira posição dentro do colchetes, 
isso mostrou que o percurso seria horizontal, porque o índice da linha ficava parado enquanto j as- 
sumia todas as colunas possíveis para aquela linha. Já na segunda forma apresentada, i variou de O 
a 3 e foi usada na segunda posição dentro dos colchetes, indicando que o percurso seria vertical, pois 
o índice da coluna ficava parado enquanto j assumia todas as linhas possíveis para aquela coluna. 


7.4 Matriz em JAVA 


7.4.1 Definição de matriz 


Uma matriz pode ser definida como um conjunto de variáveis de mesmo tipo e identificadas pelo mesmo 
nome. Essas variáveis são diferenciadas por meio da especificação de suas posições dentro dessa estrutura. 

A linguagem JAVA permite a declaração de matrizes unidimensionais (mais conhecidas como vetores 
— descritos no capítulo anterior), bidimensionais e multidimensionais. As matrizes mais utilizadas possuem 
duas dimensões. Para cada dimensão deve ser adotado um índice. 

Os índices utilizados na linguagem JAVA para identificar as posições de uma matriz começam sempre em 
O (zero) e vão até o tamanho da dimensão menos uma unidade. Os índices de uma matriz em JAVA devem 
sempre ser representados por um dos tipos inteiros disponíveis na linguagem. 


7.42 Declaração de matriz 


Matrizes em JAVA são definidas pela existência de colchetes vazios antes ou depois do nome da variável, 
no momento da declaração. Logo depois, deve ser feita a definição do tamanho de cada dimensão da matriz. 
Em JAVA, a indicação do tamanho das dimensões da matriz pode ser feita por um valor inteiro fixo (repre- 
sentado por um literal? ou uma constante) ou por uma variável, cujo valor é definido em tempo de execução. 


3 Literal é um valor fixo, definido quando se escreve o programa. Por exemplo: double x=10.3; onde 10.3 é um literal. cnar mat 
[][]= new char[3][7]; onde 3 e 7, escritos dentro dos colchetes, são literais. 
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Para utilizar uma matriz em JAVA, é preciso seguir dois passos: 


1º PASSO: DECLARAR UMA VARIÁVEL QUE FARÁ REFERÊNCIA AOS ELEMENTOS 


tipo dos dados nome variável[][][]...-[]; 
Os pares de colchetes vazios após o nome da variável definem que a variável será uma estrutura mul- 
tidimensional. 


2º PASSO: DEFINIR O TAMANHO DAS DIMENSÕES DA MATRIZ 


nome variável = new tipo dos dados [dimensão1l][dimensão2] [dimensão3]...[dimensãoN]; 


onde: 

tipo dos dados: é o tipo de dados que poderá ser armazenado na sequência de variáveis que formam 
a matriz; 

nome variável: é o nome dado à variável do tipo matriz; 

[dimensão1]: representa o tamanho da primeira dimensão da matriz; 

[dimensão2]: representa o tamanho da segunda dimensão da matriz; 

[dimensãoN]: representa o tamanho da n-ésima dimensão da matriz. 


74.3 Exemplos de matriz 

Nos exemplos a seguir, são utilizadas duas linhas de comando: a primeira declara uma matriz, e a se- 
gunda define o tamanho das dimensões. 

É importante ressaltar que, em JAVA, os pares de colchetes podem aparecer todos antes do nome da 
variável ou depois do nome da variável ou, ainda, alguns antes e outros posteriormente. Assim, todos os 
exemplos a seguir são válidos. 


Exemplo 1: 


float X[][]; 
X = new float[2][6]; 


A declaração anterior criou uma variável chamada x contendo duas linhas (0 a 1) com seis colunas cada 
(0 a 5), capazes de armazenar números reais, como pode ser observado a seguir. 


Exemplo 2: 


char [][ IMAT; 
MAT = new char[4][3]; 


A declaração anterior criou uma variável chamada mar contendo quatro linhas (0 a 3) com três colunas 
cada (0 a 2), capazes de armazenar caracteres, como pode ser observado a seguir. 


MAT 1 


0 1 2 
RR 


Exemplo 3: 


int [][JYI]; 
Y = new int[2][4][3]; 
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A declaração anterior criou uma variável chamada Y contendo duas linhas (0 a 1) com quatro colunas (0 
a 3) e três profundidades (0 a 2), capazes de armazenar números inteiros, como pode ser observado a seguir. 


2 


1 
0 


i f 


Além das formas descritas nos exemplos anteriores, a linguagem JAVA também permite que os dois pas- 
sos necessários para utilização de uma matriz (declaração e dimensionamento) sejam realizados em apenas 
uma linha de comando. Assim, nos exemplos apresentados a seguir, utilizou-se uma forma condensada de 
criação de matriz, onde a declaração e o dimensionamento são feitos utilizando-se uma única linha. 


Exemplo 4: 
float X[][] = new float[2][6]; 


A declaração anterior criou uma variável chamada x contendo duas linhas (0 a 1) com seis colunas cada 
(0 a 5), capazes de armazenar números reais, como pode ser observado a seguir. 


Exemplo 5: 
char [][]MAT = new char[4][3]; 


A declaração anterior criou uma variável chamada mar contendo quatro linhas (0 a 3) com três colunas 
cada (0 a 2), capazes de armazenar caracteres, como pode ser observado a seguir. 


MAT 1 


0 1 2 
RR 


Exemplo 6: 
int [][]Y[] = new int[2][4][3]; 


A declaração anterior criou uma variável chamada Y contendo duas linhas (0 a 1) com quatro colunas 
(0 a 3) e três profundidades (0 a 2), capazes de armazenar números inteiros, como pode ser observado a 
seguir. 
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E importante lembrar, também, que o tamanho das dimensões não precisa ser feito em um mesmo mo- 
mento. Os exemplos que seguem mostram essa flexibilidade. 


Exemplo 7: 


Nesse exemplo (a numeração das linhas foi utilizada apenas para facilitar a explicação), foi definido 
pela linha 1 que a variável Y é uma matriz bidimensional. A linha 2 estabelece que o tamanho da primeira 
dimensão é 2, ou seja, essa matriz tem duas linhas, identificadas pelos índices O e 1. Na linha 3, foi definido 
o tamanho da linha 0, que passou a ter 5 colunas. Já a linha 4 define o tamanho da linha 1, que passou a 
ter 2 colunas. 


a ane Siig 

- Y = new int[2][]; 
a Y[0] new int[5]; 
a SAL] new int[2]; 


BB wNH 


Uma representação dessa matriz poderia ser: 


Matriz Y 0 


1 


0 1 2 3 4 


744 Atribuindo valores a uma matriz 


Atribuir valor a uma matriz significa armazenar uma informação em um de seus elementos, identifica- 
do de forma única por meio de seus índices. 


x[1][4]=5; — Atribui o valor 5 à posição identificada pelos índices 1 (22 linha) e 4 (5º coluna). 


0 1 2 3 4 5 


MAT[3][2] = ‘D’; — Atribui a letra D à posição identificada pelos índices 3 (42 linha) e 2 
(3? coluna). 


0 1 2 
of | 
MAT a] | 
2 [| 
a] | D 


Y[0][3][1] = 12; — Atribui o valor 12 à posição identificada pelos índices O (12 linha), 3 
(4º coluna) e 1 (2: profundidade). 


12 
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74.5 Preenchendo uma matriz 


Preencher uma matriz significa percorrer todos os seus elementos, atribuindo-lhes um valor. Esse valor 
pode ser recebido do usuário, por meio do teclado, ou pode ser gerado pelo programa. 

Nos exemplos a seguir, todos os elementos de uma matriz bidimensional são acessados e a eles são 
atribuídos valores inteiros, digitados pelo usuário. 


Exemplo 1: 


int X[][] = new int[7][3]; 
Scanner e = new Scanner (System. in); 
for (i=0;i<7,i++) 
{ 
for (j=0;j<3; j++) 
X[i][j] = e.nextInt(); 
} 


Como a matriz possui 7 linhas e 3 colunas, o exemplo apresentou duas estruturas de repetição for para 
garantir que a variável i assumisse todos os valores possíveis para linha (de 0 a 6) e a variável j assumisse 
todos os valores possíveis para coluna (de 0 a 2) da matriz x. Assim, para cada execução das estruturas de 
repetição, uma posição diferente da matriz foi preenchida por um valor digitado pelo usuário por meio do 
método nextInt() da classe scanner. 


Exemplo 2: 

1. int MAT[][]; 

2. MAT = new int[3][]; 

3. MAT[0]= new int[2]; 

4. MAT[1]= new int[5]; 

5. MAT[2]= new int[3]; 

6. Scanner e = new Scanner(System.in); 
7. for (i=0;i<MAT.length; i++) 

8. { 

or for (j=0;j<MAT[i].length; j++) 
10. X[i][j] = e.nextInt(); 
Ti 


No exemplo 2, onde a numeração não faz parte do código e é utilizada apenas para explicação, usamos 
uma matriz cujas linhas têm tamanhos diferentes. 

A linha 1 indicou que mar é uma matriz bidimensional. A linha 2 definiu que a quantidade de linhas 
de mart é 3, mas não estabeleceu a quantidade de colunas. A linha 3 determinou que o tamanho da linha O 
de mar é 2. A linha 4 definiu que o tamanho da linha 1 de mar é 5. A linha 5 estipulou que o tamanho da 
linha 2 de mar é 3. 

Dessa variação de tamanho de linhas surge a necessidade de ter algum recurso para recuperar, quando 
for preciso, o tamanho de cada dimensão de uma Array (vetor ou matriz). Esse recurso é o atributo length. 

Na linha 7, podemos ver o uso de MAT. length, que significa o tamanho da primeira dimensão de mar, 
ou seja, a quantidade de linhas, que é 3. 

Na linha 9, podemos ver MAT[ i] . length, que significa o tamanho da linha i de maT. Quando i estiver 
valendo 0, esse tamanho será 2; quando i estiver valendo 1, esse tamanho será 5; e quando i estiver valendo 
2, esse tamanho será 3. 

Com as duas estruturas de repetição for, pode-se garantir que a variável i assuma todos os valores 
possíveis para cada linha (de 0 a 2) ea variável j assuma todos os valores possíveis para coluna, respeitando 
os dimensionamentos feitos. Assim, para cada execução das estruturas de repetição, uma posição diferente 
da matriz foi preenchida por um valor digitado pelo usuário, por meio do método nextInt() da classe 
scanner. 
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7.4.6 Mostrando os elementos de uma matriz 
Pode-se, também, percorrer todos os elementos da matriz, acessando seu conteúdo. 


Exemplo 1: 
for (i=0; i<l0; i++) 
{ 
for (j=0; j<6; j++) 
System.out.println(X[i][j]); 
} 


No exemplo 1 foram mostrados todos os elementos de uma matriz contendo dez linhas e seis colunas. 
Observe que são usados dois índices, i e j. Esses índices estão atrelados a estruturas de repetição que mantêm 
a variação de ambos dentro de intervalos permitidos. Ou seja, o índice i, que representa as linhas, varia de O 
a 9 e o índice j, que representa as colunas, varia de O a 5. 


Exemplo 2: 

1. for (i=0;i<MAT.length; i++) 

Do 

So for (j=0;j<MAT[i].length; j++) 

4. System.out.printin(MAT[i][5]); 
Do 


No exemplo 2, também foram mostrados todos os elementos de uma matriz. Contudo, em virtude do 
uso do atributo length (apresentado em detalhes na Seção 7.4.5), as linhas dessa matriz podem ter tama- 
nhos diferentes. 

Na linha 1, podemos ver o uso de MaT. length, que significa o tamanho da primeira dimensão de mar, 
ou seja, a quantidade de linhas. Na linha 3, podemos ver maT[i].length, que significa o tamanho da linha 
i de MAT. 

Com as duas estruturas de repetição for, pode-se garantir que a variável i assuma todos os valores possíveis 
para linha e a variável j assuma todos os valores possíveis para coluna, respeitando os dimensionamentos feitos. 
Assim, para cada execução das estruturas de repetição, uma posição diferente da matriz foi acessada e seu valor 
mostrado por meio do método printIn() da classe system. 


7.4.7 Percorrendo uma matriz 


Vimos anteriormente, nos tópicos 7.4.5 e 7.4.6, formas para preencher toda uma matriz e para mostrar 
todas as posições de uma matriz. Em tais operações, foi necessário passar por todas as posições, ou seja, foi 
preciso percorrer a matriz. 

Uma das formas mais simples de percorrer uma matriz pode ser por meio do uso de uma estrutura de 
repetição para cada dimensão da matriz. A ordem de disposição de tais estruturas de repetição define a 
forma como a matriz será percorrida. 

A seguir, apresentaremos duas formas para percorrer uma mesma matriz, chamada x, contendo 3 linhas 
e 4 colunas. 


0 4 5 1 10 

Matriz x 1 16 11 76 8 
2 9 54 32 89 

0 1 2 3 


Forma 1: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos 
gravados em cada linha. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a 
numeração à esquerda não faz parte do programa, servirá apenas para facilitar a explicação). 
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1. for(i=0,i<3;i++) 

Po sl 

Do System.out.println(“Elementos da linha “ + i); 
4. for(j=0;j<4;j++) 

Do { 

6. System.out.println(x[i,5]); 

To } 

8. + 


A primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de O a 2. Cada execução da estrutura for encontrará a segunda estrutura de repetição 
(linha 4), controlada pela variável j, que assumirá os valores dentro do intervalo de 0 a 3. Assim, cada valor 
assumido pela variável i estará associado a 4 valores da variável 5. 

Esse arranjo resolve o problema de mostrar os elementos, separando-os por linhas, já que a variável 
i ficará com valor fixo enquanto a variável 5 assumirá valores de O a 3, ou seja, formará todos os pares 
possíveis de índices. Se i estiver valendo 0, serão mostrados todos os elementos da primeira linha, já que 
serão formados os seguintes pares: x[0,0], x[0,1], x[0,2] e x[0,3]. Depois, a variável i assume o valor 1 e 
novamente a 5 terá seus valores variando de O a 3. Com isso, será possível percorrer toda a segunda linha, 
por meio da formação dos pares x[1,0], x[1,1], x[1,2] e x[1,3]. Esse processo se repetirá para os demais 
valores possíveis de i. A tabela a seguir mostra uma simulação de execução do programa. Nessa simulação, 
é importante observar como as variáveis i e j têm seus valores alterados. 


Simulação: 


MEMÓRIA TELA 


Elementos da linha O 

4 

5 

1 

10 
Elementos da linha 1 

16 

11 

76 

8 
Elementos da linha 2 

9 

54 

32 

89 


WU MN + O 


NININININ aaja 4 + O |O |O /0/0O/ H- 
WIN|-—O 


WIN + O 


A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


0 4 5 1 10 
i 16 ++ 76 8 
Matriz x 1al = E E de de 
2 54 32 89 
typ > > 
0 1 2 3 


Forma 2: precisamos percorrer a matriz, de tal forma que seja possível mostrar todos os elementos gra- 
vados em cada coluna. Para isso, utilizaremos duas estruturas de repetição, conforme mostrado a seguir (a 
numeração à esquerda não faz parte do programa, servirá apenas para facilitar a explicação). 
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1. for (i=0,i<4,i++) 

Pe 

So System.out.println(“Elementos da coluna “ + i); 
4. for (j=0;j<3; j++) 

So { 

6. System.out.println(x[j,i]); 

T } 

8. + 


À primeira estrutura de repetição (linha 1) é controlada pela variável i, que poderá assumir valores 
dentro do intervalo de O a 3. Cada execução da estrutura encontrará a segunda estrutura de repetição 
(linha 4), controlada pela variável j, que assumirá os valores dentro do intervalo de O a 2. Assim, cada 
valor assumido pela variável i estará associado a 3 valores da variável 5. Esse arranjo resolve o problema 
de mostrar os elementos, separando-os por colunas, já que a variável i ficará com valor fixo enquanto 
a variável j assumirá valores de 0 a 2, ou seja, formará todos os pares possíveis de índices. Se i estiver 
valendo 0, serão mostrados todos os elementos da primeira coluna, já que serão formados os seguintes 
pares: x[0,0], x[1,0] e x[2,0]. Depois, a variável i assumirá o valor 1 e novamente j terá seus valores 
variando de 0 a 2. Com isso, será possível percorrer toda a segunda coluna, por meio da formação dos 
pares x[0,1], x[1,1] e x[2,1]. Esse processo se repetirá para os demais valores possíveis de i. A tabela a 
seguir mostra uma simulação de execução do algoritmo. Nessa simulação é importante observar como as 
variáveis i e j têm seus valores alterados. 


Simulação: 
MEMÓRIA TELA 
i j 
(0) Elementos da coluna O 
(0) (0) 4 
0 1 16 
0 2 9 
1 Elementos da coluna 1 
1 0 5 
1 1 11 
1 2 54 
2 Elementos da coluna 2 
2 0 1 
2 1 76 
2 2 32 
3 Elementos da coluna 3 
(0) 10 
3 1 8 
3 2 89 


A figura a seguir dá outra visão da forma utilizada para percorrer a matriz. A direção das setas indica 
a mudança no valor das variáveis i e j e o caminho utilizado para percorrer a matriz. 


0 4 
Matriz x 1 16 11 76 8 
2 9 54 32 89 
0 1 2 3 


Pelas formas de percorrer uma matriz apresentadas anteriormente, podemos observar alguns pontos 
que merecem atenção: 
a mudança dos valores das varáveis i e j, que controlam as estruturas de repetição, permite a for- 
mação de todos os possíveis pares de linha e coluna existentes na matriz. 
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a mudança do valor da variável i, utilizada no for externo, acontece mais lentamente que a mudança 
da variável 5, utilizada no for interno. Logo, foi a variável i que indicou como seria o percurso: na 
primeira forma apresentada, i variou de O a 2 e foi usada na primeira posição dentro do colchetes, 
isso indicou que o percurso seria horizontal, pois o índice da linha ficava parado, enquanto j assumia 
todas as colunas possíveis para aquela linha. Já na segunda forma apresentada, i variou de 0 a 3 e 
foi usada na segunda posição dentro dos colchetes, indicando que o percurso seria vertical, porque 
o índice da coluna ficava parado, enquanto j assumia todas as linhas possíveis para aquela coluna. 


EXERCÍCIOS RESOLVIDOS 


BEER Faça um programa que preencha uma matriz M (2 X 2), calcule e mostre a matriz R, resultante da 


multiplicação dos elementos de M pelo seu maior elemento. 


(ALLTSIOIRNITIMO) Solução: 


ALGORITMO 


DECLARE mat [2,2], resultado[2,2], i, j, maior NUMÉRICO 


PARA i — 


1 ATÉ 2 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 2 FAÇA 


INÍCIO 
LEIA mat[i,j] 
FIM 


FIM 
maior +- mat[1,1] 


PARA i <— 


1 ATÉ 2 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 2 FAÇA 


INÍCIO 
SE mat[i,j] > maior 
ENTÃO maior < mat[i,5] 


FIM 
FIM 
PARA i — 1 ATÉ 2 FAÇA 
INÍCIO 
PARA j <— 1 ATÉ 2 FAÇA 
INÍCIO 
resultado[i,j] — maior * mat[i,5] 
FIM 
FIM 
PARA i — 1 ATÉ 2 FAÇA 
INÍCIO 
PARA j <— 1 ATÉ 2 FAÇA 
INÍCIO 
ESCREVA resultado[i,5] 
FIM 
FIM 


FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
EEES 


C/C++ 
GEES 
JAVA 
E) 


VEXERCACAP7NPASCALVEX1.PAS e NEXERCACAP7NPASCALNEX1.EXE 


SOLUÇÃO: 


\EXERC\CAP7\C++\EX1.CPP e \EXERC\CAP7\C++\EX1.EXE 


SOLUÇÃO: 


VEXERCACAP7NJAVANEX1. java e \EXERC\CAP7\JAVA\EX1.class 
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IFA Faça um programa que preencha uma matriz 10 x 3 com as notas de dez alunos em três provas. O 
programa deverá mostrar um relatório com o número dos alunos (número da linha) e a prova em que 
cada aluno obteve menor nota. Ao final do relatório, deverá mostrar quantos alunos tiveram menor 
nota em cada uma das provas: na prova 1, na prova 2 e na prova 3. 


(AILIGIOJRI ITIMO) Sorução: 
ALGORITMO 


DECLARE notas[10,3],qgl, q2, q3, menor, p menor, i, j NUMÉRICO 
PARA i < 1 ATÉ 10 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
LEIA notas[i,5] 
FIM 
FIM 
qio 
q2 (0) 
gs0 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA i 
menor < notas[i,1] 
p menor < 1 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
SE notas[i, j] < menor 
ENTÃO INÍCIO 
menor + notas[i, j] 
p menor <— j 
FIM 
FIM 
ESCREVA p menor 
SE p menor = 1 
ENTÃO ql — ql + 1 
SE p menor = 2 
ENTÃO q2 — q2 + 1 
SE p_menor = 3 
ENTÃO q3 — q3 + 1 
FIM 


ESCREVA ql, q2, q3 
FIM_ALGORITMO. 


ISo NM SOLUÇÃO: 
GEES VEXERCACAP7NPASCALVEX2.PAS e NEXERCACAP7NPASCALNEX2.EXE 


eyler Ra SoLução: 
GRE) \EXERC\CAP7\C++\EX2.CPP e NEXERCACAP7NC++NEX2. EXE 


RB WIAN SoLução: 
cs VEXERCÍCAP7NJAVANEX2. java e NEXERCACAP7NJAVANEX2.class 


BEAR Faça um programa que preencha: 
um vetor com oito posições, contendo nomes de lojas; 
outro vetor com quatro posições, com nomes de produtos; 


uma matriz com os preços de todos os produtos em cada loja. 
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O programa deverá mostrar todas as relações (nome do produto — nome da loja) em que o preço não 
ultrapasse R$ 120,00. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE lojas[8],produtos[4] LITERAL 
preços[4,8], i, j NUMÉRICO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
LEIA lojas[j] 
FIM 
PARA i <— 1 ATÉ 4 FAÇA 
INÍCIO 
LEIA produtos[i] 
FIM 
PARA i <— 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
LEIA preços[i, 5] 
FIM 
FIM 
PARA i <— 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
SE preços[i, j] < 120 
ENTÃO ESCREVA produtos[i], lojas[j] 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
EE VEXERCACAP7NPASCALNEX3.PAS e NEXERCACAP7NPASCALNEX3.EXE 


LETTA SoLução: 
Ens \EXERC\CAP7\C++\EX3.CPP e NEXERCACAP7NC++HNEX3. EXE 


E-G- SoLução: 
C \EXERC\CAP7\JAVA\EX3.java e \EXERC\CAP7\JAVA\EX3.class 


ÆJ Crie um programa que preencha uma matriz 10 X 20 com números inteiros e some cada uma das li- 
nhas, armazenando o resultado das somas em um vetor. A seguir, o programa deverá multiplicar cada 
elemento da matriz pela soma da linha correspondente e mostrar a matriz resultante. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mat[10,20], soma[10], i, j NUMÉRICO 
PARA i <— 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j < 1 ATÉ 20 FAÇA 
INÍCIO 
LEIA mat[i, 5] 

FIM 

FIM 
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PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
soma[i]+*< 0 
PARA j < 1 ATÉ 20 FAÇA 


INÍCIO 
soma[i] <- soma[i] + mat[i, j] 
FIM 
FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j < 1 ATÉ 20 FAÇA 
INÍCIO 
mat[i, j] «<- mat[i, j] * soma[i] 
FIM 
FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA mat [i, j] 
FIM 
FIM 


FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
GEE VEXERCACAP7NPASCALVEX4.PAS e VEXERCÍCAP7NPASCALNEX4. EXE 


VETIA Solução: 
Ce \EXERC\CAP7\C++\EX4.CPP e \EXERC\CAP7\C++\EX4. EXE 


DEGIE SoLução: 
D \EXERC\CAP7\JAVA\EX4.java e \EXERC\CAP7\JAVA\EX4.class 


EA Na teoria dos sistemas, define-se o elemento MINMAX de uma matriz como o maior elemento da 
linha em que se encontra o menor elemento da matriz. Elabore um programa que carregue uma matriz 
4 X 7 com números reais, calcule e mostre seu MINMAX e sua posição (linha e coluna). 


(AILTSIOJRN TIMÃO) Solução: 


ALGORITMO 
DECLARE mat [4,7], menor, maior, i, j, 1 menor, col NUMÉRICO 
PARA i<-1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 7 FAÇA 
INÍCIO 
LEIA mat[i, 5] 
FIM 
FIM 
menor +— mat [1, 1] 
1 menor — 1 
PARA i+ 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 7 FAÇA 
INÍCIO 
SE mat[i, j] < menor 
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ENTÃO INÍCIO 
menor +— mat [i, j] 
1 menor <— i 
FIM 
FIM 
FIM 
maior + mat [1 menor, 1] 
Colm = 1 
PARA j+< 1 ATÉ 7 FAÇA 
INÍCIO 
SE mat [1 menor, j] > maior 
ENTÃO INÍCIO 
maior +— mat [1 menor, j] 
Col 
FIM 
FIM 
ESCREVA maior, 1 menor, col 
FIM ALGORITMO. 


INNA SOLUÇÃO: 
Z] \EXERC\CAP7\PASCAL\EX5.PAS e \EXERC\CAP7\PASCAL\EX5 .EXE 


eVlt aa SoLução: 
\EXERC\CAP7\C++\EX5.CPP e \EXERC\CAP7\C++\EX5.EXE 


o] 
E-Go- SoLução: 
D EXERC\CAP7\JAVA\EX5.java e \EXERC\CAP7\JAVA\EX5.class 


EA Crie um programa que preencha uma primeira matriz de ordem 4 X 5 e uma segunda matriz 5 X 2. 
O programa deverá, também, calcular e mostrar a matriz resultante do produto matricial das duas 
matrizes anteriores, armazenando-o em uma terceira matriz de ordem 4 X 2. 


(ALLISIOJEL TIM) Solução: 


ALGORITMO 
DECLARE a[4, 5],b[5, 2],c[4, 2] NUMÉRICO 
i, j, k, soma, mult NUMÉRICO 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA a[i, 5] 
FIM 
FIM 
PARA i <- 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 2 FAÇA 
INÍCIO 
LEIA b[i, 5] 
FIM 
FIM 
soma — 0 
PARA i+ 1 ATÉ 4 FAÇA 
INÍCIO 


PARA k +<- 1 ATÉ 2 FAÇA 
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INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
multt+-ali, 5] * b[5, kJ 
soma +— soma + mult 
FIM 
c[i, k] — soma 
soma — 0 
FIM 
FIM 
PARA i <+ 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j 1 ATÉ 2 FAÇA 
INÍCIO 
ESCREVA c[i, j] 
FIM 
FIM 
FIM_ALGORITMO. 


PASCAI, SoLUÇÃO: 
e \EXERC\CAP7\PASCAL\EX6.PAS e \EXERC\CAP7\PASCAL\EX6.EXE 


LETSA SoLução: 
D \EXERC\CAP7\C++\EX6.CPP e \EXERC\CAP7\C++\EX6 .EXE 


DEGE SoLução: 
ERR VEXERCACAP7NJAVANEX6. java e \EXERC\CAP7\JAVA\EX6.class 


EA Um elemento Aij de uma matriz é dito ponto de sela da matriz A se, e somente se, Aij for, ao mesmo 
tempo, o menor elemento da linha i e o maior elemento da coluna j. Faça um programa que carregue 
uma matriz de ordem 5 X 7, verifique se a matriz possui ponto de sela e, se possuir, mostre seu valor 
e sua localização. 


(AILISIOJRI ITIMO) Sorução: 


ALGORITMO 
DECLARE mat [5,7] NUMÉRICO 
i, j, maior, menor, linha, coluna, cont NUMÉRICO 
PARA i +— 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 7 FAÇA 
INÍCIO 
LEIA mat[i, j] 
FIM 
FIM 
cont — 0 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
menor +— mat[i, 1] 
linha <— i 
coluna <— 0 
PARA j — 1 ATÉ 7 FAÇA 
INÍCIO 
SE mat [i,)] < menor 
ENTÃO INÍCIO 
menor +— mat[i, j] 
linha + i 
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coluna & j 
FIM 
FIM 
maior +— mat[1, coluna] 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
SE mat [j,coluna] > maior 
ENTÃO INÍCIO 
maior + mat[j, coluna] 
FIM 
FIM 
SE menor = maior 
ENTÃO INÍCIO 


ESCREVA “Ponto de sela = “, maior, “ na posição”, linha, coluna 
cont < cont + 1 
FIM 


FIM 
SE cont = 0 
ENTÃO ESCREVA “Não existe ponto de sela nesta matriz” 
FIM ALGORITMO. 


Io JANSJOJAN] SOLUÇÃO: 
Ee VEXERCACAP7NPASCALVEX7.PAS e NEXERCACAP7NPASCALNEX7.EXE 


VETIA Solução: 
E \EXERC\CAP7\C++\EX7.CPP e \EXERC\CAP7\C++\EX7.EXE 


JAVA SoLução: 
D \EXERC\CAP7\JAVA\EX7.java e \EXERC\CAP7\JAVA\EX7.class 


EA Elabore um programa que preencha uma matriz 6 X 4 com números inteiros, calcule e mostre quantos 
elementos dessa matriz são maiores que 30 e, em seguida, monte uma segunda matriz com os elemen- 
tos diferentes de 30. No lugar do número 30, da segunda matriz, coloque o número zero. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE mat1[6,4], mat2[6,4], i, j, qtde NUMÉRICO 
PARA i <- 1 ATÉ 6 FAÇA 
INÍCIO 
PARA j+< 1 ATÉ 4 FAÇA 
INÍCIO 
LEIA matl[i, j] 
FIM 
FIM 
qtde <— 0 
PARA i — 1 ATÉ 6 FAÇA 
INÍCIO 
PARA j+< 1 ATÉ 4 FAÇA 
INÍCIO 
SE matl[i, j] > 30 
ENTÃO qtde — qtde + 1 
FIM 
FIM 
PARA i <- 1 ATÉ 6 FAÇA 
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INÍCIO 
PARA j+< 1 ATÉ 4 FAÇA 
INÍCIO 
SE matl[i, j] = 30 
ENTÃO mat2[i, j] + 0 
SENÃO mat2[i, j] — matl[i, j] 
FIM 
FIM 
ESCREVA qtde 
PARA i <- 1 ATÉ 6 FAÇA 
INÍCIO 
PARA j+< 1 ATÉ 4 FAÇA 
INÍCIO 
ESCREVA mat2[i, j] 
FIM 
FIM 
FIM_ALGORITMO. 


PASCAL SOLUÇÃO: 


E! VEXERCACAP7NPASCALVEX8.PAS e NEXERCACAP7NPASCALNEX8.EXE 


C/c++ ENIO: 


\EXERC\CAP7\C++\EX8.CPP e \EXERC\CAP7\C++\EX8. EXE 


EE 
RB WIA NA SoLução: 
GEES 


VEXERCÍCAP7NJAVANEX8. java e NEXERCACAP7NJAVANEX8.class 


ALGORITMO 


DECLARE mat [15,5], rep[15,5], vezes[15,5] NUMÉRICO 


i, j, k, l, lin, lin2, col, x, num, qtde, achou NUMÉRICO 


PARA i <— 1 ATÉ 15 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA mat[i,5] 
FIM 
FIM 
lata => dl 
(rol = dl 
PARA i 1 ATÉ 15 FAÇA 
INÍCIO 
PARA j- 1 ATÉ 5 FAÇA 
INÍCIO 
qtde < 1 
num + mat [i,j] 
PARA k — 1 ATÉ 15 FAÇA 
INÍCIO 
PARA 1 — 1 ATÉ 5 FAÇA 
INÍCIO 
SE i <> k OU 5 <> 1 


BEAR Crie um programa que preencha uma matriz 15 X 5 com números inteiros, calcule e mostre quais 
elementos da matriz se repetem e quantas vezes cada um se repete. 


(AJLICIOJRN ITIM(O) SoLução: 


228 | Fundamentos da programação de computadores 


ENTÃO SE mat [k,1] = num 
ENTÃO qtde — qtde + 1 
FIM 
FIM 
SE qtde > 1 
ENTÃO INÍCIO 
achou + 0 
SE col = 1 
ENTÃO lin2 <— lin-1 
SENÃO lin? — lin 
PARA k — 1 ATÉ lin2 FAÇA 
INÍCIO 
SE (k < lin2) 
ENTÃO x — 5 
SENÃO x < col-1 
PARA 1 — 1 ATÉ x FAÇA 
INÍCIO 
SE num = rep[k,1] 
ENTÃO achou <— 1 
FIM 
FIM 
SE achou = 0 
ENTÃO INÍCIO 
rep[lin,col] +< num 
vezes[lin,col] < qtde 
Cole ccColTtol 
SE col > 5 
ENTÃO INÍCIO 
Lia = iim Go dl 
(ol = 11 
FIM 
FIM 
FIM 
FIM 
FIM 
PARA i — 1 ATÉ lin FAÇA 
INÍCIO 
SE i < lin 
ENTÃO x — 5 
SENÃO x + col-l 
PARA j — 1 ATÉ x FAÇA 
INÍCIO 
ESCREVA “O número “,rep[i,j], “ repetiu “,vezes[i,J],” 
vezes” 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
E VEXERCACAP7NPASCALVEX9.PAS e NEXERCACAP7NPASCALNEX9 . EXE 


C/C++ Sorução: 
GEES \EXERC\CAP7\C++\EX9.CPP e NEXERCACAP7NC++HNEX9. EXE 


RANMA SoLução: 
D \EXERC\CAP7\JAVA\EX9.java e \EXERC\CAP7\JAVA\EX9.class 
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ELA Elabore um programa que preencha uma matriz 10 X 10 com números inteiros, execute as trocas es- 
pecificadas a seguir e mostre a matriz resultante: 


a linha 2 com a linha 8; 

a coluna 4 com a coluna 10; 

a diagonal principal com a diagonal secundária; 
a linha 5 com a coluna 10. 


(AILISIOJRN TIMÃO) Sorução: 


ALGORITMO 
DECLARE mat[10,10], aux, i, j NUMÉRICO 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA mat[i, j] 
FIM 
FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
aux < mat [2, i] 
mat[2,1i] + mat[8,i] 
mat[8, i] <— aux 


FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
aux + mat [i, 4] 
mat[i, 4] < mat[i,10] 
mat[i, 10] — aux 
FIM 
J= L0 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
aux + mat[i, i] 
mat[i, i] — mat[i, 5] 
mat[i, j] — aux 
a) = 9) sol 
FIM 
PARA j <— 1 ATÉ 10 FAÇA 
INÍCIO 
aux + mat[5, j] 
mat[5, j] + mat [5,10] 
mat[j, 10] — aux 
FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA mat[i, j] 
FIM 
FIM 


FIM ALGORITMO. 


PASCAL EO 
D \EXERC\CAP7\PASCAL\EX10.PAS e \EXERC\CAP7\PASCAL\EX10.EXE 


C/c++ ERES 
c= \EXERC\CAP7\C++\EX10.CPP e \EXERC\CAP7\C++\EX10.EXE 
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BAIA SoLução: 
RES VEXERCACAP7NJAVANEX10.java e \EXERC\CAP7\JAVA\EX10.class 


EEB Crie um programa que preencha uma matriz 8 X 8 com números inteiros e mostre uma mensagem 
dizendo se a matriz digitada é simétrica. Uma matriz só pode ser considerada simétrica se A[i,5j] = 
A(j,il. 

ALIRIM) Solução: 


ALGORITMO 
DECLARE mat[8,8], i, j NUMÉRICO 
simetria LÓGICO 
PARA i <— 1 ATÉ 8 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
LEIA mat[i, j] 
FIM 
FIM 
simetria + verdadeiro 
PARA i <- 1 ATÉ 8 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
SE mat[i, j] % mat[5, i] 
ENTÃO simetria <— falso 
FIM 
FIM 
SE simetria = verdadeiro 
ENTÃO ESCREVA “Matriz Simétrica” 
SENÃO ESCREVA “Matriz Assimétrica” 
FIM ALGORITMO. 


PASCAL [RSioRtoiton 
D \EXERC\CAP7\PASCAL\EX11.PAS e \EXERC\CAP7\PASCAL\EX11.EXE 


eyler Ra SoLuçÃo: 
GERE \EXERC\CAP7\C++\EX11.CPP e \EXERC\CAP7\C++\EX11.EXE 


RB WIA NA SoLução: 
(RR \EXERC\CAP7\JAVA\EX11.java e \EXERC\CAP7\JAVA\EX11.class 


EFA Elabore um programa que preencha uma matriz 4 X 4 com números inteiros e verifique se essa matriz 
forma o chamado quadrado mágico. Um quadrado mágico é formado quando a soma dos elementos 
de cada linha é igual à soma dos elementos de cada coluna dessa linha, é igual à soma dos elementos 
da diagonal principal e, também, é igual à soma dos elementos da diagonal secundária. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mat [4,4] NUMÉRICO 
soma linha[4] NUMÉRICO 
soma coluna[4] NUMÉRICO 
soma diagp, soma diags, i, j, compara NUMÉRICO 
q magico LÓGICO 
PARA i <— 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j <— 1 ATÉ 4 FAÇA 
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INÍCIO 
LEIA mat[1,5] 
FIM 
FIM 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
soma linha[i] <— 0 
PARA j <— 1 ATÉ 4 FAÇA 
INÍCIO 
soma linha[i] < soma linha[i] + mat[i,5] 
FIM 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
soma coluna[i] — 0 
PARA j <— 1 ATÉ 4 FAÇA 
INÍCIO 
soma coluna[i] — soma coluna[i] + mat[j,i] 
FIM 
FIM 
soma diagp <— 0 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
soma diagp +- soma diagp + mat[i,i] 
FIM 
soma diags <— 0 
us É 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
soma diags +<- soma diags + mat[i,j] 
je gol 
FIM 


q magico + verdadeiro 
PARA i<-1 ATÉ 4 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
SE soma linha[i] % soma coluna[5] 
ENTÃO q magico <— falso 
FIM 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
SE soma linha[i] * soma diagp 
ENTÃO q magico < falso 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
SE soma linha[i] * soma diags 
ENTÃO q magico < falso 
FIM 


SE q magico = verdadeiro 
ENTÃO ESCREVA “Forma quadrado mágico” 
SENÃO ESCREVA “Não forma quadrado mágico” 
FIM ALGORITMO. 
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PASCAL, [SORO to 
D \EXERC\CAP7\PASCAL\EX12.PAS e \EXERC\CAP7\PASCAL\EX12.EXE 


Lon aTa SoLução: 
\EXERC\CAP7\C++\EX12.CPP e \EXERC\CAP7\C++\EX12.EXE 


D 
BAIANA SoLução: 
GEE: VEXERCICAP7NJAVANEX12. java e NEXERCICAP7NJAVANEX12.class 


EEJ Faça um programa que preencha: 
um vetor com os nomes de cinco produtos; 
uma matriz 5 X 4 com os preços dos cinco produtos em quatro lojas diferentes; 
outro vetor com o custo do transporte dos cinco produtos. 


O programa deverá preencher uma segunda matriz 5 X 4 com os valores dos impostos de cada produto, 
de acordo com a tabela a seguir. 


PREÇO 9% DE IMPOSTO 
Até R$ 50,00 5 
Entre R$ 50,00 e R$ 100,00 (inclusive) 10 
Acima de R$ 100,00 20 


O programa deverá mostrar, ainda, um relatório com o nome do produto, o número da loja onde o 
produto é encontrado, o valor do imposto a pagar, o custo de transporte, o preço e o preço final (preço 
acrescido do valor do imposto e do custo do transporte). 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE nome[5] LITERAL 

preco, imp[5,4], custo[5], i, j, final NUMÉRICO 
NUMÉRICO PARA i <— 1 ATÉ 5 FAÇA 


INÍCIO 
LEIA nome[i] 
FIM 
PARA i <— 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
LEIA preco[i,5] 
FIM 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA custo[i] 
FIM 
PARA i <- 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j+<- 1 ATÉ 4 FAÇA 
INÍCIO 


SE preco[i,j] < 50 
ENTÃO imp[i,j]l+<-preco[i,j] * 5 / 100 
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SENÃO SE preco[i,j] > 50 E preco[i,j] <= 100 
ENTÃO imp[i,j] — preco[i,)]*10/100 
SENÃO imp[i,j] — preco[i,5]*15/100 


FIM 
FIM 
PARA i <- 1 ATÉ 5 FAÇA 

INÍCIO 

ESCREVA “Nome do produto “,nome[i] 

ESCREVA “Custo = “, custo[i] 

PARA j+<- 1 ATÉ 4 FAÇA 
INÍCIO 
final + preco[i,j] + imp[i,j] + custo[i] 
ESCREVA “Imposto na loja “, j,” =“, imp[i,5] 
ESCREVA “Preço na loja “, j, “ = “, preco[i,5] 
ESCREVA “Preço final na loja “,j, “ = “, final 
FIM 

FIM 


FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
NEXERCACAP7NPASCALVEX13.PAS e NEXERCÍCAP7NPASCALNEX13.EXE 


C/C++ SoLUÇÃO: 
Eai! \EXERC\CAP7\C++\EX13.CPP e NEXERCACAP7AC++NEX13. EXE 


BAIA SOLUÇÃO: 
VEXERCACAP7NJAVAlEX13.java e NEXERCICAP7NJAVANEX13.class 


ELA Faça um programa que receba: 
um vetor com o nome de cinco cidades diferentes; 
uma matriz 5 X 5 com a distância entre as cidades, e na diagonal principal deve ser colocada auto- 
maticamente a distância zero, ou seja, não deve ser permitida a digitação; 
o consumo de combustível de um veículo, ou seja, quantos quilômetros esse veículo percorre com 


um litro de combustível. 
O programa deverá calcular e mostrar: 


os percursos que não ultrapassam 250 quilômetros (os percursos são compostos pelos nomes das 
cidades de origem e pelos nomes das cidades de destino); 


todos os percursos (nome da cidade de origem e nome da cidade de destino), junto com a quantida- 
de de combustível necessária para o veículo percorrê-los. 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE cidade[5] LITERAL 
distancia[5,5], i, j, consumo, qtde NUMÉRICO 
NUMÉRICO PARA i < 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA cidade[i] 
FIM 
PARA i <— 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
SE i=j 
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ENTÃO distancia[i, j] — 0 
SENÃO LEIA distancia[i, j] 


FIM 
FIM 
PARA i < 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
SE distancia[i, j] <= 250 E distancia[i, j] > 0 
ENTÃO ESCREVA “Distancia: “, distancia[i, j], “ entre “, cidade[i], 
“e”, cidade[5] 
FIM 
FIM 


LEIA consumo 
PARA i — 1 ATÉ 5 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
SE i É j 
ENTÃO INÍCIO 
qtde — distancia[i, j] / consumo 
ESCREVA “Consumo entre “, cidade[i], “ e “, cidade[j], “ = 
“, qtde 
FIM 
FIM 
FIM 


FIM_ALGORITMO. 


INSON SOLUÇÃO: 
\EXERC\CAP7\PASCAL\EX14.PAS e \EXERC\CAP7\PASCAL\EX14.EXE 


VETA Solução: 
\EXERC\CAP7\C++\EX14.CPP e \EXERC\CAP7\C++\EX14.EXE 


RANMA SoLução: 
\EXERC\CAP7\JAVA\EX14.java e NEXERCICAP7NJAVANEX14.class 


HA Elabore um programa que preencha: 
um vetor com cinco números inteiros; 
outro vetor com dez números inteiros; 
uma matriz 4 X 3, também com números inteiros. 


O programa deverá calcular e mostrar: 


o maior elemento do primeiro vetor multiplicado pelo menor elemento do segundo vetor. O resulta- 
do dessa multiplicação, adicionado aos elementos digitados na matriz, dará origem a uma segunda 
matriz (resultante); 


a soma dos elementos pares de cada linha da matriz resultante; 
a quantidade de elementos entre 1 e 5 em cada coluna da matriz resultante. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE vet1[5], vet2[10], mat[4,3], mat result [4,3] NUMÉRICO 
i, j, maior, menor, mult, soma, qtde NUMÉRICO 

PARA i — 1 ATÉ 5 FAÇA 
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INÍCIO 
LEIA vetl[i] 
FIM 
PARA i <— 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vet2[i] 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
LEIA mat[i,5] 
FIM 
FIM 
maior <— vet1[1] 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
SE vetl[i] > maior 
ENTÃO maior — vet1[i] 
FIM 
menor + vet2[1] 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
SE vet2[i] < menor 
ENTÃO menor — vet2[i] 
FIM 
mult + maior * menor 
PARA i<-1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
mat result[i, j] — mat[i, j] + mult 
FIM 
FIM 
ESCREVA “Matriz resultante” 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
ESCREVA mat result[i,5] 
FIM 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
soma <— 0 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
SE RESTO(mat result[1,5]/2) = 0 
ENTÃO soma < soma + mat result[i,5] 
FIM 
ESCREVA “Soma dos elementos pares da linha “, i, “ da matriz resultante = “, 
soma 
FIM 
PARA j+<- 1 ATÉ 3 FAÇA 
INÍCIO 
qtde <— 0 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
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SE mat result[i,j] > 1 E mat result[i,j] < 5 
ENTÃO qtde — qtde + 1 
FIM 
ESCREVA “Total de números entre 1 e 5 na coluna “, j, “ da matriz resultante 
= “,qtde 
FIM 
FIM ALGORITMO. 


PASCAL, SOLUÇÃO: 
E VEXERCACAP7NPASCALVEX15.PAS e NEXERCACAP7NPASCALNEX15.EXE 


LETTA SoLução: 
E! \EXERC\CAP7\C++\EX15.CPP e NEXERCACAP7NC++HNEX15. EXE 


E-G- SoLução: 
Es VEXERCACAP7NJAVANEX15.java e NEXERCICAP7NJAVANEX15.class 


HA Faça um programa que preencha uma matriz 7 X 7 de números inteiros e crie dois vetores com sete po- 
sições cada um que contenham, respectivamente, o maior elemento de cada uma das linhas e o menor 
elemento de cada uma das colunas. Escreva a matriz e os dois vetores gerados. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mat [7,7], vet1l[7], vet2[7] NUMÉRICO 
i, j, maior, menor NUMÉRICO 
PARA i — 1 ATÉ 7 FAÇA 
INÍCIO 
PARA j <— 1 ATÉ 7 FAÇA 
INÍCIO 
LEIA mat[i, 5] 
FIM 
FIM 
PARA i — 1 ATÉ 7 FAÇA 
INÍCIO 
maior +— mat[i,1] 
PARA j — 2 ATÉ 7 FAÇA 
INÍCIO 
SE (mat[i, j] > maior) 
ENTÃO maior + mat[i, j] 


FIM 
vetl[i] <- maior 
FIM 
PARA i — 1 ATÉ 7 FAÇA 
INÍCIO 
menor <— mat [1,1] 
PARA j — 2 ATÉ 7 FAÇA 
INÍCIO 
SE (mat[j, i] < menor) 
ENTÃO menor < mat[j, i] 
FIM 
vet2[i] + menor 
FIM 
PARA i+ 1 ATÉ 7 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 7 FAÇA 
INÍCIO 
ESCREVA mat[i, j] 
FIM 


FIM 
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PARA i4 1 ATÉ 7 FAÇA 
INÍCIO 
ESCREVA vetl[i] 


FIM 
PARA i+ 1 ATÉ 7 FAÇA 
INÍCIO 
ESCREVA vet2[i] 
FIM 


FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
mE \EXERC\CAP7\PASCAL\EX16.PAS e \EXERC\CAP7\PASCAL\EX16.EXE 


Lon Ta SoLução: 
a \EXERC\CAP7\C++\EX16.CPP e \EXERC\CAP7\C++\EX16.EXE 


RB WIANA SoLução: 
GEES 


VEXERCACAP7NJAVANEX16.java e NEXERCICAP7NJAVANEX16.class 


EFA Faça um programa que utilize uma matriz 5 X 5 a qual aceite três tipos de valores: múltiplos de 5, 
múltiplos de 11 e múltiplos de 13. Devem ser lidos apenas valores maiores que zero. Após a leitura, os 
números devem ser distribuídos da seguinte maneira: 

os múltiplos de 5 devem ocupar a diagonal principal; 
os múltiplos de 11 devem ficar acima da diagonal principal; 
os múltiplos de 13 devem ficar abaixo da diagonal principal. 
Como alguns números podem ser múltiplos de 5, de 11 e também de 13 (por exemplo, 55 é múltiplo de 5 e 
de 11; 65 é múltiplo de 5 e de 13), deve-se, primeiro, verificar se o número digitado é múltiplo de 5. Caso não seja, 
deve-se verificar se é múltiplo de 11. Caso não seja, deve-se verificar se é múltiplo de 13. Caso não seja, o progra- 


ma deverá mostrar a mensagem Número inválido (por exemplo, o número 55 deverá ser considerado múltiplo de 
5, pois esta é a comparação que será feita primeiro). 


Segue-se um exemplo. 


5 44 11 33 55. 
26 15 77 99 88 
39 13 10 121 22 


52 78 65 40 132 


91 117 104 143 25 


Esse programa deverá observar as seguintes situações: 


quando o usuário digitar um múltiplo de 5 e não houver mais espaço na diagonal principal, deverá 
mostrar a mensagem Diagonal totalmente preenchida; 


quando o usuário digitar um múltiplo de 11 e não houver mais espaço disponível na matriz, deverá 
mostrar a mensagem Não existe espaço acima da diagonal principal; 


quando o usuário digitar um múltiplo de 13 e não houver mais espaço disponível na matriz, deverá 
mostrar a mensagem Não existe espaço abaixo da diagonal principal; 


quando a matriz estiver totalmente preenchida, deverá mostrar todos os elementos da matriz, junto 
com suas posições (linha e coluna). 
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(AILIGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mat [5, 5] NUMÉRICO 
i, j, dp, lin ac, col ac, lin ab NUMÉRICO 
col ab, num, r, cont dp, cont ac, cont ab NUMÉRICO 


dp — 1 

latim as s d 
col ac + 2 
lin ab + 2 
col ab < 1 


cont dp < 0 
cont ac+<-0 
cont ab<-0 
ENQUANTO cont ac < 10 OU cont ab < 10 OU cont dp < 5 FAÇA 
INÍCIO 
LEIA num 
r — RESTO (num/5) 
SE r = 0 
ENTÃO INÍCIO 
SE cont dp < 5 
ENTÃO INÍCIO 
mat[dp,dp] — num dp — dp + 1 
cont dp + cont dp + 1 
FIM 
SENÃO ESCREVA “Não existe mais espaço para múltiplos de 5” 
FIM 
SENÃO INÍCIO 
r — RESTO (num/11) 
SE r = 0 
ENTÃO INÍCIO 
SE cont ac < 10 
ENTÃO INÍCIO 
mat[lin ac,col ac] « num 
col ac + col ac + 1 
SE col ac > 5 
ENTÃO INÍCIO 
lin ac — lin ac + 1 
col ac — lin ac + 1 


FIM 
cont ac < cont ac + 1 
FIM 
SENÃO ESCREVA “Não existe mais espaço para múltiplos de 11” 


FIM 
SENÃO INÍCIO 
r <— RESTO (num/13) 
SE r =0 
ENTÃO INÍCIO 
SE cont ab < 10 
ENTÃO INÍCIO 
mat [lin ab,col ab] « num 
col ab + col ab+ 1 
SE col ab >= lin ab 
ENTÃO INÍCIO 
lin ab — lin ab + 1 
col ab < 1 
FIM 
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cont ab + cont ab + 1 
FIM 
SENÃO ESCREVA “Não existe mais espaço para 
múltiplos de 11” 
FIM 
SENÃO INÍCIO 
r <— RESTO (num/13) 
SE r = 0 
ENTÃO INÍCIO 
SE cont ab < 10 
ENTÃO INÍCIO 
mat [lin ab,col ab] « num 
col ab « col ab+ 1 
SE col ab >= lin ab 
ENTÃO INÍCIO 
lin ab — lin ab + 1 
col ab — 1 
FIM 
cont ab + cont ab + 1 
FIM 
SENÃO ESCREVA “Não existe mais espaço para 
múltiplos de 13” 
FIM 
SENÃO ESCREVA “Digite um número múltiplo de 5 ou 
de 11 ou de 13” 
FIM 
FIM 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
ESCREVA mat[i,j] 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL EOLO 
VEXERCACAP7NPASCALNEX17.PAS e NVEXERCICAP7NPASCALNEX17.EXE 


c/c++ Solução: 
E. \EXERC\CAP7\C++\EX17.CPP e NEXERCACAP7NC++NEX17.EXE 


DEGE SoLução: 
VEXERCACAP7NJAVANEX17.java e NEXERCICAP7NJAVANEX17.class 


EEJ Crie um programa que leia um vetor vet contendo 18 elementos. A seguir, o programa deverá distribuir 
esses elementos em uma matriz 3 x 6 e, no final, mostrar a matriz gerada. 


Veja a seguir um exemplo do que seu programa deverá fazer. 


vet| 3 |25| 1 |58/|97/|43/65|32/27|19/10|6|88/13/34|57|89|87 
mat 3 25 1 58 97 43 
65 32 27 19 10 6 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE vet [18], mat [3,6], i, j, lin, col NUMÉRICO 
PARA i < 1 ATÉ 18 FAÇA 


INÍCIO 
LEIA vet[i] 
FIM 
Laim s= il 
(col <= dl 
PARA i < 1 ATÉ 18 FAÇA 
INÍCIO 


mat [lin,col] + vet[i] 
Col «= (efojdl 4» dl 
SE col > 6 
ENTÃO INÍCIO 
sia = Jim sr dl 
(Col <= dl 
FIM 
FIM 
PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 6 FAÇA 
INÍCIO 
ESCREVA “Elemento “, à, “> “, 5 , mat[i,j] 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
Em NEXERCACAP7NPASCALVEX18.PAS e VEXERCICAP7NPASCALNEX18.EXE 


ylen Ra Sorução: 
D \EXERC\CAP7\C++\EX18.CPP e \EXERC\CAP7\C++\EX18.EXE 


E-G- SoLução: 
CED \EXERC\CAP7\JAVA\EX18.java e \EXERC\CAP7\JAVA\EX18.class 


ELA Faça um programa que utilize uma matriz com dimensões máximas de cinco linhas e quatro colunas. 
Solicite que sejam digitados os números que serão armazenados na matriz da seguinte maneira: 

se o número digitado for par, deve ser armazenado em uma linha de índice par; 
se o número digitado for ímpar, deve ser armazenado em uma linha de índice ímpar; 
as linhas devem ser preenchidas de cima para baixo (por exemplo, os números pares digitados 
devem ser armazenados inicialmente na primeira linha par; quando essa linha estiver totalmente 
preenchida, deve ser utilizada a segunda linha par e assim sucessivamente; o mesmo procedimento 
deve ser adotado para os números ímpares); 
quando não couberem mais números pares ou ímpares, o programa deverá mostrar uma mensagem 
ao usuário; 
quando a matriz estiver totalmente preenchida, o programa deverá encerrar a leitura dos números 
e mostrar todos os elementos armazenados na matriz. 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mat [5,4], i, j, num, r NUMÉRICO 


lin p, col p, lin i, col i, tot NUMÉRICO 
2 


lin p — 
(ol jo) = 
INDE 
ol at = 
tot — 0 
REPITA 
SE tot +Æ 20 
ENTÃO INÍCIO 
LEIA num 
r + RESTO (num/2) 
SE r = 0 
ENTÃO INÍCIO 
SE lin p > 4 
ENTÃO ESCREVA “Sem espaço para números pares” 
SENÃO INÍCIO 

mat[lin p,col p] — num 

(rol jo) = (elonl, jo) se dl 

SE col p > 4 

ENTÃO INÍCIO 
linp — linp + 2 col p << 1 
FIM 


1 
1 
1 


FIM 
FIM 
SENÃO INÍCIO 
SE lin i > 5 
ENTÃO ESCREVA “Sem espaço para números ímpares” 
SENÃO INÍCIO 
mat [lin i,col i] « num 
(Sol dt += (Sol al sr dl 
SE col i > 4 
ENTÃO INÍCIO 
Tinei Jlotim, st dr 2 
IL at == dl 
FIM 
FIM 
FIM 


tot <— tot + 1 
FIM 
ATÉ tot = 20 
ESCREVA “Matriz totalmente preenchida” 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
ESCREVA mat[i,5] 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 

VEXERCÍCAP7NPASCALNEX19.PAS e NEXERCACAP7NPASCALNEX19.EXE 
VLE Ea SoLução: 

\EXERC\CAP7\C++\EX19.CPP e NEXERCACAP7AC++EX19. EXE 


ANIMA SoLução: 
GR VEXERCACAP7NJAVANEX19. java e NEXERCICAP7NJAVANEX19.class 
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EXA Crie um programa que utilize uma matriz com dimensões máximas de cinco linhas e quatro colunas 
e solicite que sejam digitados os números (desordenadamente), armazenando-os, ordenadamente, na 
matriz. 


Observe o exemplo que se segue. 
Supondo que sejam digitados os seguintes números: 10-1-2-20-30-17-98-65-24-12-5-8 
-73-55-31-100-120-110-114-130, estes deverão ser armazenados na matriz da seguinte maneira: 


1 2 5 8 
10 12 17 20 
24 30 31 55 
65 73 98 100 
110 114 120 130 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE num[5,4] NUMÉRICO 
num aux, i, j, k, 1, m, n, lin, col NUMÉRICO 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
LEIA num aux 
mr tes dis = 
ENTÃO num[i, j] — num aux 
SENÃO INICIO 
k = dl 
L <= i 
ENQUANTO num[k, 1] < num aux E (k É i OU 1 É j) FAÇA 
INÍCIO 
1 e= ap dl 
SE 1>4 
ENTÃO INÍCIO 
le <> de sp dl 
L = i 
FIM 
FIM 
m = g 
nee 
ENQUANTO m É k OU n É 1 FAÇA 
INÍCIO 
SE n-1 < 1 ENTÃO 
INÍCIO 
lin — m-1 
col — 4 
FIM 
SENÃO INÍCIO 
lin <— m 
col — n-1 
FIM 
num[m] [n] — num[lin][col] 
o + mel 
SER: 
ENTÃO INÍCIO 
n | 4 
m + m-1 
FIM 
FIM 
num[k][1] — num aux 
FIM 
FIM 
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FIM 

PARA i — 1 ATÉ 5 FAÇA 

INÍCIO 

PARA j — 1 ATÉ 4 FAÇA 

INÍCIO 

ESCREVA “Elemento da posição “, i, “-", j, “ =“, num[i][J] 
FIM 

FIM 

FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
E NEXERCACAP7NPASCALVEX20.PAS e NVEXERCACAP7NPASCALNEX20.EXE 


c/c++ Elia 
D \EXERC\CAP7\C++\EX20.CPP e \EXERC\CAP7\C++\EX20.EXE 


BAIA SOLUÇÃO: 
D \EXERC\CAP7\JAVA\EX20.java e \EXERC\CAP7\JAVA\EX20.class 


FAN Crie um programa que utilize uma matriz com as dimensões fornecidas pelo usuário e execute as so- 
licitações a seguir. 


Para realizar essa tarefa, a matriz deverá ser obrigatoriamente quadrada (número igual de linhas e co- 
lunas). Sendo assim, solicite que seja informada a dimensão da matriz. 

Posteriormente, o programa deverá realizar a leitura dos elementos que vão compor a matriz. Por fim, 
deverá somar e mostrar os elementos que estão abaixo da diagonal secundária. 

Veja o exemplo. 

Imagine que sejam informados números, conforme apresentado nesta matriz. 


19 45 32 87 


12 | 36 | 6 | 25 
O resultado do problema seria: 98 + 32 + 87 + 36 + 65 + 25 = 343 


(AILTSIOJRI ITIMO) Solução: 


ALGORITMO 
DECLARE num[100,100],dim, 1, c, soma, cont NUMÉRICO 
REPITA 
ESCREVA “Digite a dimensão da matriz (quadrada) - no máximo 100” 
LEIA dim 
ATÉ dim >= 1 E dim <= 100 
Al = dl 
Gs dl 
ENQUANTO 1 < dim FAÇA 
INÍCIO 
ENQUANTO c < dim FAÇA 
INÍCIO 


LEIA num[1,c] 
cien 
FIM 
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1 — 1+1 
G => dl 
FIM 
soma + 0 
cont < 0 
L= 2) 
c+< dim 
ENQUANTO 1 < dim FAÇA 
INÍCIO 
ENQUANTO c > dim-cont FAÇA 
INÍCIO 
ESCREVA num[1,C] 
soma + soma + num[1,C] 
Gs o dl 
FIM 
cont + cont + 1 
L= L sp dl 
c+< dim 
FIM 
ESCREVA soma 
FIM ALGORITMO. 


PASCAL [RSioRtoiton 
[Ee VEXERCACAP7NPASCALVEX21.PAS e NEXERCACAP7NPASCALNEX21.EXE 


VETIA Solução: 
D \EXERC\CAP7\C++\EX21.CPP e \EXERC\CAP7\C++\EX21.EXE 


PEGS SoLução: 
(ER VEXERCACAP7NJAVANEX21.java e NEXERCICAP7NJAVANEX21.class 


EYA Faça um programa que receba o estoque atual de três produtos, armazenados em quatro armazéns, e 
coloque esses dados em uma matriz 5 X 3. Considerando que a última linha dessa matriz contenha o 
custo de cada produto, o programa deverá calcular e mostrar: 


a quantidade de itens quadrados em cada armazém; 
qual armazém possui maior estoque do produto 2; 
qual armazém possui menor estoque; 
qual o custo total de cada produto; 
qual o custo total de cada armazém. 
Devem ser desconsiderados empates. 
SOLUÇÃO: 


ALGORITMO 
DECLARE prod[5,3], tot arm, maior e NUMÉRICO 

menor e, custo p, custo a, i, j, ind a NUMÉRICO 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
LEIA prod[i,j] 
FIM 
FIM 


PARA i — 1 ATÉ 3 FAÇA 
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INÍCIO 
LEIA prod[5,i] 
FIM 
PARA i 1 ATÉ 4 FAÇA 
INÍCIO 
tot arm 0 
PARA j 1 ATÉ 3 FAÇA 
INÍCIO 
tot arm+<-tot arm + prod[i,5] 
FIM 
ESCREVA “O total de itens no armazém “,i, 
SE i=1 
ENTÃO INÍCIO 
menor e + tot arm 
inda + i 
diwel E — al 
FIM 
SENÃO INÍCIO 
SE tot arm < menor e 
ENTÃO INÍCIO 
menor e + tot arm 
rindia = dt 
FIM 


vo = E cone Guam 


FIM 
FIM 
ESCREVA “Armazém com menor estoque”, ind a 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
SE i=1 
ENTÃO INÍCIO 
maior e — prod[i,2] 
inda <— à 
FIM 
SENÃO INÍCIO 
SE prod[i,2] > maior e 
ENTÃO INÍCIO 
maior e — prod[i,2] 
inda <— à 
FIM 
FIM 
FIM 
ESCREVA “O maior estoque do produto 2 está no armazém” ,ind a 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
custo p< 0 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 


custo p+- custo p + prod[i,5] 


FIM 
custo p+<- custo p * prod[5,5] 
ESCREVA “O custo total do produto “, j , “ = “,custo p 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
custo a< 0 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
custo a+- custo a + (prod[i,j] * prod[5,5]) 
FIM 
ESCREVA “O custo total do armazém “, i ,” =”, custo a 
FIM 


FIM ALGORITMO. 
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PASCAL, SOLUÇÃO: 
RES VEXERCACAP7NPASCALVEX22.PAS e NEXERCACAP7NPASCALNEX22.EXE 


ylen Ra Sorução: 
\EXERC\CAP7\C++\EX22.CPP e NEXERCACAP7NC++HNEX22. EXE 


C 
RNA SoLução: 
EEE VEXERCICAP7NJAVANEX22. java e NEXERCICAP7NJAVANEX22.class 


PER Crie um programa que receba as vendas semanais (de um mês) de cinco vendedores de uma loja e ar- 
mazene essas vendas em uma matriz. O programa deverá calcular e mostrar: 


o total de vendas do mês de cada vendedor; 
o total de vendas de cada semana (todos os vendedores juntos); 
o total de vendas do mês. 


(ALLISIOJRNTITIMO) Solução: 


ALGORITMO 
DECLARE vendas[4,5], tot ven, tot sem, tot geral, i, 5 NUMÉRICO 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA vendas[i, j] 

FIM 

FIM 

PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 


tot ven < 0 
PARA j <— 1 ATÉ 4 FAÇA 


INÍCIO 
tot ven <— tot ven + vendas[j, i] 
FIM 
ESCREVA tot ven 
FIM 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 


tot sem< 0 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
tot sem<-tot sem + vendas[i, j] 
FIM 
ESCREVA tot sem 
FIM 
tot geral < 0 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
tot geral <- tot geral + vendas[i, j] 
FIM 
FIM 


ESCREVA tot geral 
FIM ALGORITMO. 
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PASCAI, SoLUÇÃO: 
Gina VEXERCACAP7NPASCALNVEX23.PAS e NEXERCICAP7NPASCALNEX23.EXE 


eylen Za SoLução: 
\EXERC\CAP7\C++\EX23.CPP e NEXERCACAP7NC++NEX23. EXE 


ET] 
BLWIAN SoLução: 
E \EXERC\CAP7\JAVA\EX23.java e \EXERC\CAP7\JAVA\EX23.class 


EZY Uma escola deseja controlar as médias das disciplinas que seus alunos cursam. Sabe-se que nessa es- 
cola existem três turmas, com oito alunos cada uma, e cada aluno cursa quatro disciplinas. Crie um 
programa que armazene essas médias em uma matriz 3 X 8 X 4. Depois da leitura, ele deverá calcular 
e mostrar: 


a média geral de cada aluno; 
a média de cada turma. 
(AJLIGJOJRILITIM]O) SoLução: 


ALGORITMO 


DECLARE medias[3][8][4], i, j, k, media aluno, media turma NUMÉRICO 
PARA i — 1 ATÉ 3 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
PARA k — 1 ATÉ 4 FAÇA 
INÍCIO 
LEIA medias[il][5][k] 
FIM 
FIM 
FIM 
PARA i <— 1 ATÉ 3 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
media aluno < 0 
PARA k — 1 ATÉ 4 FAÇA 
INÍCIO 
media aluno + media aluno + medias[il][5][k] 
FIM 
media aluno +- media aluno / 4 
ESCREVA “A média do aluno “, j, “ na turma “, i, “ =“, media aluno 
FIM 
FIM 
PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 


media turma < 0 
PARA j — 1 ATÉ 8 FAÇA 
INÍCIO 
PARA k — 1 ATÉ 4 FAÇA 
INÍCIO 
media turma < media turma + medias[i][j][k] 
FIM 
FIM 
media turma +— media turma / (8 * 4) 
ESCREVA “A média da turma “, i, “ = “, media turma 
FIM 
FIM ALGORITMO. 
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PASCAL, SOLUÇÃO: 
RE VEXERCACAP7NPASCALVEX24.PAS e VEXERCACAP7NPASCALNEX24.EXE 


C/C++ Sorução: 
\EXERC\CAP7\C++\EX24.CPP e NEXERCACAP7NC++HNEX24. EXE 


ET 
E-Go- SoLução: 
EEE VEXERCICAP7NJAVANEX24. java e NEXERCICAP7NJAVANEX24.class 


FER Elabore um programa que receba as vendas de cinco produtos em três lojas diferentes, e em dois meses con- 
secutivos. O programa deverá armazenar essas vendas em duas matrizes 5 X 3. O bimestre é uma matriz 
5 X 3, resultado da soma das duas matrizes anteriores. Deverá ainda calcular e mostrar: 


as vendas de cada produto, em cada loja, no bimestre; 
a maior venda do bimestre; 

o total vendido, por loja, no bimestre; 

o total vendido de cada produto no bimestre. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mesl[5,3], mes2[5,3], bim[5,3] NUMÉRICO 
i, j, tot prod, tot loja, maior NUMÉRICO 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
LEIA mesl[i,j] 
FIM 
FIM 
PARA i <— 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
LEIA mes2[i,5] 
FIM 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
bim[i,i] + mesl[i,5] + mes2[i,5] 
ESCREVA bim[1,5] 
SE i=1 E j=1 
ENTÃO maior — bim[i,5] 
SENÃO SE bim[i,j] > maior 
ENTÃO maior — bim[i,5] 
FIM 
FIM 
ESCREVA maior 
PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 
tot loja — 0 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
tot loja+t-tot loja + bim[j,i] 
FIM 
ESCREVA tot loja 
FIM 
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PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
tot prod + 0 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
tot prod+-tot prod + bim[i,5] 
FIM 
ESCREVA tot prod 
FIM 


FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
D \EXERC\CAP7\PASCAL\EX25.PAS e \EXERC\CAP7\PASCAL\EX25.EXE 


c/c++ Solução: 
G] \EXERC\CAP7\C++\EX25.CPP e \EXERC\CAP7\C++\EX25. EXE 


RAIA SOLUÇÃO: 
D \EXERC\CAP7\JAVA\EX25.JAVA e \EXERC\CAP7\JAVA\EX25.class 


EXERCÍCIOS PROPOSTOS 


EEH Faça um programa que preencha uma matriz 3 X 5 com números inteiros, calcule e mostre a quantidade de 
elementos entre 15 e 20. 


IFA Crie um programa que preencha uma matriz 2 X 4 com números inteiros, calcule e mostre: 
a quantidade de elementos entre 12 e 20 em cada linha; 
a média dos elementos pares da matriz. 
REA Flabore um programa que preencha uma matriz 6 X 3, calcule e mostre: 
o maior elemento da matriz e sua respectiva posição, ou seja, linha e coluna; 
o menor elemento da matriz e sua respectiva posição, ou seja, linha e coluna. 
J Faça um programa que receba: 
as notas de 15 alunos em cinco provas diferentes e armazene-as em uma matriz 15 X 5; 


os nomes dos 15 alunos e armazene-os em um vetor de 15 posições. 
O programa deverá calcular e mostrar: 


para cada aluno, o nome, a média aritmética das cinco provas e a situação (aprovado, reprovado 
ou exame); 


a média da classe. 


REA Elabore um programa que preencha uma matriz 12 X 4 com os valores das vendas de uma loja, em que cada 
linha representa um mês do ano e cada coluna representa uma semana do mês. O programa deverá calcular 
e mostrar: 


o total vendido em cada mês do ano, mostrando o nome do mês por extenso; 
o total vendido em cada semana durante todo o ano; 
o total vendido pela loja no ano. 


KA Faça um programa que preencha uma matriz 20 X 10 com números inteiros, e some cada uma das colunas, 
armazenando o resultado da soma em um vetor. À seguir, o programa deverá multiplicar cada elemento da 
matriz pela soma da coluna e mostrar a matriz resultante. 


IEA Elabore um programa que preencha uma matriz M de ordem 4 X 6 e uma segunda matriz N de ordem 6 x 
4, calcule e imprima a soma das linhas de M com as colunas de N. 
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REA Crie um programa que preencha duas matrizes 3 X 8 com números inteiros, calcule e mostre: 
a soma das duas matrizes, resultando em uma terceira matriz também de ordem 3 X 8; 
a diferença das duas matrizes, resultando em uma quarta matriz também de ordem 3 X 8. 


REA Faça um programa que preencha uma matriz 3 X 3 com números reais e outro valor numérico digitado pelo 
usuário. O programa deverá calcular e mostrar a matriz resultante da multiplicação do número digitado por 
cada elemento da matriz. 


ELA Crie um programa que preencha uma matriz 5 X 5 com números inteiros, calcule e mostre a soma: 
dos elementos da linha 4; 
dos elementos da coluna 2; 
dos elementos da diagonal principal; 
dos elementos da diagonal secundária; 
de todos os elementos da matriz. 


EHA Elabore um programa que: receba a idade de oito alunos e armazene-as em um vetor; armazene o código 
de cinco disciplinas em outro vetor; armazene em uma matriz a quantidade de provas que cada aluno fez 
em cada disciplina. 


EFA O programa deverá calcular e mostrar: 
a quantidade de alunos com idade entre 18 e 25 anos que fizeram mais de duas provas em deter- 
minada disciplina cujo código é digitado pelo usuário. O usuário poderá digitar um código não 
cadastrado; nesse caso, o programa deverá mostrar uma mensagem de erro; 
uma listagem contendo o código dos alunos que fizeram menos que três provas em determinada 
disciplina, seguido do código da disciplina; 
a média de idade dos alunos que não fizeram nenhuma prova em alguma disciplina. Cuidado para 
não contar duas vezes o mesmo aluno. 


EEA Elabore um programa que: preencha uma matriz 6 X 4; recalcule a matriz digitada, onde cada linha de- 
verá ser multiplicada pelo maior elemento da linha em questão; mostre a matriz resultante. 


ELA Faça um programa que preencha uma matriz 2 X 3, calcule e mostre a quantidade de elementos da ma- 
triz que não pertencem ao intervalo [5,15]. 


BEER Crie um programa que preencha uma matriz 12 X 13 e divida todos os elementos de cada linha pelo 
maior elemento em módulo daquela linha. O programa deverá escrever a matriz lida e a modificada. 


HA Elabore um programa que preencha uma matriz 5 X 5 e crie dois vetores de cinco posições cada um, que 
contenham, respectivamente, as somas das linhas e das colunas da matriz. O programa deverá escrever 
a matriz e os vetores criados. 


EFA Faça um programa que preencha e mostre a média dos elementos da diagonal principal de uma matriz 
10 x 10. 


EEJ Crie um programa que preencha uma matriz 5 X 5 de números reais, calcule e mostre a soma dos ele- 
mentos da diagonal secundária. 


ELJ Faça um programa que preencha uma matriz 8 X 6 de inteiros, calcule e mostre a média dos elementos 
das linhas pares da matriz. 


EYJ Elabore um programa que preencha uma matriz 5 X 5 com números reais e encontre o maior valor da 
matriz. A seguir, o programa deverá multiplicar cada elemento da diagonal principal pelo maior valor 
encontrado e mostrar a matriz resultante após as multiplicações. 


PIE Faça um programa que preencha uma matriz 5 X 5 de números reais. A seguir, o programa deverá 
multiplicar cada linha pelo elemento da diagonal principal daquela linha e mostrar a matriz após as 
multiplicações. 

EFA Crie um programa que preencha uma matriz 6 X 10, some as colunas individualmente e acumule as so- 
mas na 72 linha da matriz. O programa deverá mostrar o resultado de cada coluna. 


Capítulo 7 Matriz | 251 


EA Faça um programa que preencha uma matriz 3 X 4, calcule e mostre: 
a quantidade de elementos pares; 
a soma dos elementos ímpares; 
a média de todos os elementos. 


FEZA Elabore um programa que preencha uma matriz 4 X 5, calcule e mostre um vetor com cinco posições, 
onde cada posição contém a soma dos elementos de cada coluna da matriz. O programa deverá mostrar 
apenas os elementos do vetor maiores que dez. Se não existir nenhum elemento maior que dez, deverá 
mostrar uma mensagem. 


FER Crie um programa que: 
receba o preço de dez produtos e armazene-os em um vetor; 


receba a quantidade estocada de cada um desses produtos, em cinco armazéns diferentes, utilizando 
uma matriz 5 X 10. 
O programa deverá calcular e mostrar: 


a quantidade de produtos estocados em cada um dos armazéns; 

a quantidade de cada um dos produtos estocados, em todos os armazéns juntos; 
o preço do produto que possui maior estoque em um único armazém; 

o menor estoque armazenado; 


o custo de cada armazém. 


CAPÍTULO 


8 Sub-rotina 


8.1 Sub-rotinas (programação modularizada) 


Sub-rotinas, também chamadas subprogramas, são blocos de instruções que realizam tarefas específi- 
cas. O código de uma sub-rotina é carregado uma vez e pode ser executado quantas vezes forem necessárias. 
Como o problema pode ser subdividido em pequenas tarefas, os programas tendem a ficar menores e mais 
organizados. 

Os programas, em geral, são executados linearmente, uma linha após a outra, até o fim. Entretanto, 
quando são utilizadas sub-rotinas, é possível a realização de desvios na execução dos programas. Esses des- 
vios são efetuados quando uma função é chamada pelo programa principal. Observe o exemplo a seguir (a 
numeração das linhas à esquerda está sendo utilizada apenas para facilitar a explicação). 


1. ALGORITMO 

2. DECLARE sal, aum, novo sal NUMÉRICO 
3. LEIA sal 

4. aum + calculo (sal) 

5. novo sal + sal + aum 

6. ESCREVA “Novo salário é”, novo sal 
7. FIM ALGORITMO. 


8. SUB-ROTINA calculo (sal NUMÉRICO) // passagem de parâmetro por valor 
So DECLARE perc, valor NUMÉRICO 

10. LEIA perc 

Adi valor +— sal * perc / 100 

12. RETORNE valor 

13. FIM SUB ROTINA calculo 


O algoritmo apresentado tem como objetivo receber o valor atual do salário de um funcionário e calcular 
o novo salário. Para resolver esse problema, utilizou-se o programa principal (representado pelo bloco de ins- 
truções entre as linhas 1 e 7) e uma sub-rotina (representada pelo bloco de instruções entre as linhas 8 e 13). 

O programa principal é executado linearmente até a linha 4. Nesse ponto, existe uma chamada à sub- 
-rotina calculo (que recebe como parâmetro o valor do salário inicial) e o programa principal fica tempo- 
rariamente suspenso. À ordem de execução das instruções é, então, desviada para a linha 8, onde começa a 
sub-rotina calculo. À execução só volta ao programa principal quando o comando RETORNE for executado 
(linha 12). Esse comando é responsável, também, por devolver ao programa principal um valor calculado 
dentro da sub-rotina (nesse exemplo, foi devolvido o conteúdo da variável valor). À execução do programa 
principal é retomada exatamente no ponto em que foi interrompida; dessa maneira, o valor devolvido pela 
sub-rotina é atribuído à variável aum (linha 4). A partir daí, o programa volta a ser executado linearmente 
até o fim (linha 7). 

O exemplo apresentado mostra a utilização de uma sub-rotina que recebe um parâmetro (o valor atual 
do salário) e que, ao final, retorna um valor (aumento que será dado ao salário) para quem a chamou. Po- 
rém, as sub-rotinas podem não receber parâmetros nem retornar valor. 
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Outro ponto que precisa ser destacado é que, dentro das sub-rotinas, pode ocorrer declaração de 
variáveis, chamadas variáveis locais. Elas recebem esse nome porque podem ser utilizadas apenas dentro 
da sub-rotina. Quando a execução desta chega ao fim, essas variáveis são destruídas e seus conteúdos são 
perdidos. 

Variáveis declaradas fora de qualquer sub-rotina são chamadas globais. Elas recebem esse nome porque 
qualquer ponto do programa, incluindo as sub-rotinas, pode utilizá-las. São destruídas quando a execução 
do programa chega ao fim. 


see Observação 


Não se aconselha a utilização excessiva de variáveis globais, por tornar difícil a manutenção 
e a busca por erros nos programas. 


No algoritmo usado como exemplo anteriormente, tem-se 3 variáveis globais, declaradas na linha 2 e 
denominadas sal, aum é novo sal. Na linha 9, existe a declaração de 2 variáveis locais da sub-rotina cal- 
culo. São elas: perc e valor. 

É importante salientar que, na linha 4, onde a sub-rotina calculo é chamada, a variável sal está sendo 
passada como parâmetro e, na linha 8, cabeçalho da sub-rotina calculo, uma variável, que pode ou não ter 
o mesmo nome, está recebendo o valor do parâmetro. 

O parâmetro pode ser passado por valor e, então, a variável do cabeçalho se comportará como uma 
variável local da sub-rotina. 

O parâmetro pode ser passado por referência e, então, a variável do cabeçalho se comportará como 
uma variável global. 

À passagem de parâmetros por valor ou por referência depende da sintaxe de cada linguagem e as pró- 
ximas seções demonstrarão essas especificidades. 


Exemplo de variáveis locais e globais: 


1. ALGORITMO 

2. DECLARE X, Y NUMÉRICO // variáveis globais 

Ba. 4 SS i 

fls NE = 2) 

5. ESCREVA “VALORES INICIAIS” 

GEES CREVA Sa O A eva 

Teo SL // chamada da sub-rotina Sl, sem parâmetros 
8. ESCREVA “VALORES DEPOIS DA EXECUÇÃO DA SUB-ROTINA S1” 

OR ESCREVA env 

10. S2(X,Y) //chamada da sub-rotina S2, com parâmetros por valor 
11. ESCREVA “VALORES DEPOIS DA EXECUÇÃO DA SUB-ROTINA S2” 

127 ESCREVA Da env Rr 

13. S3(X,Y) // chamada da sub-rotina S3, com parâmetros por referência 
14. ESCREVA “VALORES DEPOIS DA EXECUÇÃO DA SUB-ROTINA S3” 

TS ESCREVA SE e vo = yr 


16. FIM ALGORITMO. 


17. SUB ROTINA S1 
18. // sub-rotina sem parâmetros e sem retorno 
19. DECLARE X, Y, Z NUMÉRICO // variáveis locais da sub-rotina S1 


20. Xx <— 8 
Bila SO > TO 
22 Vá = 85) 


23. ESCREVA “VALORES IMPRESSOS DENTRO DA SUB-ROTINA S1” 
24. ESCREVA “X = “,X 
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25% 
26. 
27. 


28. 
29. 
30. 
31. 
32. 
33. 
34. 
SSF 
36. 
Slo 
38. 


39. 
40. 
Asa 
42. 
43. 
44. 
45. 
46. 
47. 
48. 
49. 


ESCREVA “Y = “2,Y 
ESCREVA “Z = “,2Z 
FIM SUB ROTINA S1 


SUB ROTINA S2 (X,Y NUMÉRICO) 
// sub-rotina com parâmetro por valor e sem retorno 


DECLARE Z NUMÉRICO // variável local da sub-rotina S2 
Ms DO SP A2 

de= SE sa 

E = to 

ESCREVA “VALORES IMPRESSOS DENTRO DA SUB-ROTINA S2” 

ESCREVA “X = “,X 

ESCREVA “Y = “,Y 

ESCREVA “Z = “,2Z 


FIM SUB ROTINA S2 


SUB ROTINA S3 (X,Y NUMÉRICO ) 
// sub-rotina com parâmetro por referência e sem retorno 


DECLARE A NUMÉRICO // variável local da sub-rotina S3 
IA SOC E 

HE = OM o dl 

VE = Atos 2 

ESCREVA “VALORES IMPRESSOS DENTRO DA SUB-ROTINA S3” 

ESCREVA “X = “,X 

ESCREVA “Y = “,Y 

ESCREVA “A = “,A 


FIM SUB ROTINA S3 


O algoritmo anterior gera a saída a seguir: 


globais 
X JY 
1 

2 


VARIÁVEIS 
locais da locais da | locais da aha 
sub-rotina sub- sub-rotina Saída na tela 
- executada 
sl -rotina s2 s3 


XIYIZIXIYIZIXIYIA 


3 
4 
5 VALORES INICIAIS 
6 
7 


X=1eY=2 
17 
8 20 
10 21 
5 22 
23 VALORES IMPRESSOS DENTRO DA SUB-ROTINA S1 
24 X=8 
25 Y=10 
26 Z= 


8 VALORES DEPOIS DA EXECUÇÃO DA SUB-ROTINA S1 
9 X=1eY=2 


10 

1 2 28 
5 31 
4 32 

7 35 


34 VALORES IMPRESSOS DENTRO DA SUB-ROTINA S2 
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VARIÁVEIS 
locais da locais da | locais da Linha 
globais | sub-rotina sub- sub-rotina Saída na tela 
si -rotina s2 s3 scai 
35 X=3 
36 Y=4 
37 Z=7 
11 VALORES DEPOIS DA EXECUÇÃO DA SUB-ROTINA S2 
12 X=1eY=2 
13 
1 2 39 
3 42 
(0) (0) 43 
0 0 44 
45 VALORES IMPRESSOS DENTRO DA SUB-ROTINA S3 
46 X=0 
47 Y=0 
48 A=3 


14 VALORES DEPOIS DA EXECUÇÃO DA SUB-ROTINA S3 
15 X=0eY=0 


8.2 Sub-rotinas em PASCAL (procedures, functions e units) 


A linguagem PASCAL possibilita a modularização por meio de procedures (procedimentos), functions 
(funções) e units (unidades). As sub-rotinas do tipo procedures (procedimentos) e functions (funções) devem 
ter seus códigos descritos antes do BEGIN do programa principal. Apenas as units (unidades) apresentam 
sintaxe diferenciada e descrita na Seção 8.2.7. 

As variáveis globais, ou seja, aquelas que são reconhecidas por todas as partes do programa, devem ser 
declaradas antes do BEGIN do programa principal. As variáveis locais devem ser declaradas dentro das sub- 
-rotinas e são reconhecidas apenas na sub-rotina onde foram declaradas. 

A seguir, um programa exemplo que soma dois números digitados pelo usuário será utilizado para de- 
monstrar os diferentes tipos de sub-rotinas. 


8.2.1 Procedures sem passagem de parâmetros 


As procedures (procedimentos) são rotinas chamadas pelo programa principal para executar alguma 
operação específica, mas não retornam valor para quem as chamou. Possuem a seguinte sintaxe: 


PROCEDURE nome da procedure; 
declaração de variáveis locais; 
BEGIN 

comandos ; 
END; 


Quando o programa encontra uma linha contendo o nome da procedure, o fluxo da execução é desvia- 
do para as linhas contidas dentro dela. Essa execução só retornará ao fluxo normal quando a execução da 
procedure chegar ao fim. 

A seguir, é apresentado um exemplo de procedure sem parâmetros (a numeração das linhas não faz 
parte do programa) com a utilização de variáveis globais. 


PROGRAM EXEMPLO; 

USES CRT; 

VAR A, B, S : INTEGER; (variáveis globais) 
PROCEDURE SOMAR; 

BEGIN 


U e WIN 
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6. S := A+ B; 

75 END; 

8. BEGIN (início do programa principal) 
9. CLRSCR; 

10. WRITELN('Digite o primeiro número: '); 

Lilo READLN(A); 

T2. WRITELN('Digite o segundo número: '); 

i3; READLN (B); 

14. SOMAR; {chamada da sub-rotina SOMAR} 
15 WRITELN('Soma = ',5); 

16. READLN; 

T7 END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 
8. Posteriormente, executa as linhas 9 a 14. Na linha 14, existe a chamada a uma procedure. O programa 
principal é desviado para a procedure, denominada somar. Assim, o fluxo de execução do programa vai 
para a linha 4, executando toda a procedure, ou seja, da linha 4 à 7. Em seguida, ele retorna à linha 15, 
exatamente abaixo da linha onde ocorreu o desvio. Executa as linhas 15, 16 e 17 e o programa é encerrado. 

A seguir, é apresentado um exemplo de procedure sem parâmetros (a numeração das linhas não faz 
parte do programa) com a utilização de variáveis locais. 


Is PROGRAM EXEMPLO; 

2. USES CRT; 

Jo PROCEDURE SOMAR; 

4. VAR A, B, S: INTEGER; (variáveis locais da sub-rotina SOMAR) 
55 BEGIN 

6. WRITELN('Digite o primeiro número: '); 

To READLN(A); 

8. WRITELN('Digite o segundo número: '); 

9. READLN (B); 

10. SEE di SP lilo 

ris WRITELN('Soma = ʻ,S); 

Da END; 

rg BEGIN {início do programa principal} 
14. CLRSCR; 

5 SOMAR ; {chamada da sub-rotina SOMAR) 
16. READLN; 

TEIAS END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 13. 
Posteriormente, executa as linhas 14 e 15. Na linha 15, existe a chamada a uma procedure. O programa 
principal é desviado para a procedure, denominada somar. Assim, o fluxo de execução do programa vai 
para a linha 3, executando toda a procedure, ou seja, as linhas 4 à 12. Em seguida, ele retorna à linha 16, 
exatamente abaixo da linha onde ocorreu o desvio. Executa as linhas 16 e 17 e o programa é encerrado. 


8.2.2 Procedures com passagem de parâmetros por valor 


Pode-se utilizar procedure com passagem de parâmetros, ou seja, no momento em que a execução da 
procedure é solicitada, alguns valores lhe são fornecidos. Observe a sintaxe: 


PROCEDURE nome da procedure (parâmetros:tipo dos dados); 
declaração de variáveis locais; 
BEGIN 
comandos ; 
END; 
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A seguir, é mostrado um exemplo de procedure com passagem de parâmetros por valor, ou seja, os 
parâmetros são variáveis locais da sub-rotina (a numeração das linhas não faz parte do programa). 


Ha 
. 


O Oo JAQUE WUN 


10. 
1E 
12. 
Ilsia 
14. 
15 
16. 
Ilgi 
18. 


PROGRAM EXEMPLO; 

USES CRT; 

VAR A, B: INTEGER; {variáveis globais} 

PROCEDURE SOMAR(X,Y: INTEGER); 

VAR S: INTEGER; {variável local da sub-rotina SOMAR} 
BEGIN 

SO 5 5 an Y, 

WRITELN('Soma = ',5); 

END; 


BEGIN {início do programa principal) 
CLRSCR; 

WRITELN('Digite o primeiro número: '); 

READLN(A); 

WRITELN('Digite o segundo número: '); 

READLN(B); 

SOMAR (A,B); {chamada da sub-rotina SOMAR) 
READLN; 

END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 10. 
Posteriormente, executa as linhas 11 a 16. Na linha 16, existe a chamada a uma procedure. O programa 
principal é desviado para a procedure, denominada SOMAR, que possui as variáveis A e B como parâme- 


tros. Ássim, 
linhas 5 a 9. 


o fluxo de execução do programa vai para a linha 4, executando toda a procedure, ou seja, as 
O primeiro parâmetro é a variável A e será passada para a variável x. O segundo parâmetro é a 


variável B e será passada para a variável y. Em seguida, ele retorna à linha 17, exatamente abaixo da linha 
onde ocorreu o desvio. Executa as linhas 17 e 18 e o programa é encerrado. 

A linguagem PASCAL não permite a passagem de vetores e matrizes como parâmetros da mesma forma 
em que são passados parâmetros de tipos primitivos (INTEGER, REAL, STRING € CHAR). Para passar um vetor 
ou uma matriz como parâmetro é necessário definir um novo tipo. 

Exemplo de vetor passado como parâmetro para uma sub-rotina: 


PROGRAM VETOR; 
USES CRT; 


TYPE X 


= ARRAY[1..5] OF INTEGER; 


VAR I: INTEGER; 
W:X; 
PROCEDURE MOSTRAR(Y:X); 


BEGIN 


WRITELN('MOSTRANDO O VETOR NA SUB-ROTINA'); 


FOR 


I:=1 TO 5 DO 


BEGIN 
WRITELN(Y[I]); 


END; 
END; 


BEGIN 
CLRSCR; 


{BEGIN DO PROGRAMA PRINCIPAL} 


WRITELN('DIGITANDO OS NÚMEROS DO VETOR '); 


FOR I:= 


BEGIN 


1 TO 5 DO 


READLN(W[I]); 
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END; 

MOSTRAR(NW) ; {CHAMADA DA SUB-ROTINA MOSTRAR) 
READLN; 

END. 


8.2.3 Procedures com passagem de parâmetros por referência 


Pode-se utilizar procedure com passagem de parâmetros, ou seja, no momento em que a execução da 
procedure é solicitada, alguns valores lhe são fornecidos. Observe a sintaxe: 


PROCEDURE nome da procedure(VAR parâmetros:tipo dos dados); 
declaração de variáveis locais; 
BEGIN 
comandos ; 
END; 


A seguir, é mostrado um exemplo de procedure com passagem de parâmetros por referência, ou seja, 
os parâmetros se comportam como variáveis globais (a numeração das linhas não faz parte do programa). 


Io PROGRAM EXEMPLO; 

Do USES CRT; 

Sin VAR A, B: INTEGER; {variáveis globais) 

4. PROCEDURE SOMAR(VAR X,Y: INTEGER); 

Do VAR S: INTEGER; (variável local da sub-rotina SOMAR) 
6. BEGIN 

Tha Sp SEDA Gr Lo 

8. WRITELN('Soma = ',5); 

9. END; 

10. BEGIN {início do programa principal) 

Lia CLRSCR; 

12; WRITELN('Digite o primeiro número: '); 

13. READLN(A); 

14. WRITELN('Digite o segundo número: '); 

15. READLN(B); 

16. SOMAR (A,B); {chamada da sub-rotina SOMAR) 
7a READLN; 

18. END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 10. 
Posteriormente, executa as linhas 11 a 16. Na linha 16, existe a chamada a uma procedure. O programa 
principal é desviado para a procedure, denominada SOMAR, que possui as variáveis A e B como parâmetros. 
Assim, o fluxo de execução do programa vai para a linha 4, executando toda a procedure, ou seja, as linhas 
5a 9.0 primeiro parâmetro é a variável A e será passada para a variável x. O segundo parâmetro é a vari- 
ável Be será passada para a variável y. Como os parâmetros foram passados por referência e isso é identifi- 
cado pela presença da palavra vAR no cabeçalho da procedure, qualquer alteração nos valores de x ou de Y 
será também refletida nas variáveis A e B, respectivamente. Em seguida, ele retorna à linha 17, exatamente 
abaixo da linha onde ocorreu o desvio. Executa as linhas 17 e 18 e o programa é encerrado. 


8.2.4 Function sem passagem de parâmetros 


Uma function (função) tem o mesmo objetivo que uma procedure, ou seja, desviar a execução do pro- 
grama principal para realizar uma tarefa específica, com uma única diferença: uma function sempre retorna 
um valor. À sintaxe de uma function é: 
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FUNCTION nome da function : tipo de dado do valor retornado; 
declaração de variáveis locais; 
BEGIN 
comandos ; 
END; 


É importante ressaltar que, para que ocorra o retorno de algum valor para quem chamou a function, 
deve-se atribuir tal valor a uma variável cujo nome seja igual ao dado à function. 

A chamada à function acontece atribuindo seu nome a uma variável ou a uma condição, que receberá o 
retorno produzido. À seguir, é apresentado um exemplo (a numeração das linhas não faz parte do programa). 


Ie PROGRAM EXEMPLO; 

Do USES CRT; 

So VAR A, B, S : INTEGER; (variáveis globais) 

4. FUNCTION SOMAR: INTEGER; 

SE BEGIN 

6. SOMAR := A + B; 

T END; 

8. BEGIN {início do programa principal} 
9. CLRSCR; 

10. WRITELN('Digite o primeiro número: '); 

11. READLN (A); 

12. WRITELN('Digite o segundo número: '); 

13. READLN(B); 

14. S := SOMAR; {chamada da sub-rotina SOMAR) 
TSS WRITELN('Soma = ʻ,S); 

16. READLN; 

WA END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 8. 
Posteriormente, executa as linhas 9 a 14. Na linha 14, existe a chamada a uma function. O programa prin- 
cipal é desviado para a function, denominada somar. Assim, o fluxo de execução do programa vai para a 
linha 4, executando toda a function, ou seja, da linha 4 à 7. Em seguida, ele retorna à linha 14, atribuindo 
o valor retornado à variável s. Por fim, executa as linhas 15, 16 e 17, e o programa é encerrado. 


8.2.5 Function com passagem de parâmetros por valor 


Uma function pode receber parâmetros no momento em que é chamada. Os valores informados são 
copiados, sequencialmente, em variáveis descritas em seu cabeçalho. A sintaxe correta é a seguinte: 


FUNCTION nome da function(parâmetros:tipo dos dados):tipo de dado do valor retornado; 
declaração de variáveis locais; 
BEGIN 
comandos ; 
END; 


A chamada a uma function acontece atribuindo seu nome a uma variável ou a uma condição, que 
receberá o retorno ao término de sua execução. No momento da chamada, são informados, também, os 
parâmetros que deverão ser levados para a function. A seguir, é apresentado um exemplo de function com 
passagem de parâmetros por valor, ou seja, os parâmetros são variáveis locais da sub-rotina (a numeração 
das linhas não faz parte do programa). 
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o PROGRAM EXEMPLO; 

Do USES CRT; 

Se VAR A, B, S : INTEGER; (variáveis globais) 

4. FUNCTION SOMAR(X,Y: INTEGER): INTEGER; 

Do BEGIN 

6. SOMAR := X + Y; 

TE END; 

8. BEGIN {início do programa principal) 
9. CLRSCR; 

10. WRITELN('Digite o primeiro número: '); 

Lilo READLN(A); 

12. WRITELN('Digite o segundo número: '); 

13. READLN (B); 

14. S := SOMAR(A,B); {chamada da sub-rotina SOMAR} 
T5: WRITELN('Soma = ʻ,S); 

16. READLN; 

17. END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 
8. Posteriormente, executa as linhas 9 a 14. Na linha 14, existe a chamada a uma function. O programa 
principal é desviado para a function, denominada somar. Assim, o fluxo de execução do programa vai para 
a linha 4, executando toda a function, ou seja, da linha 4 à 7. O primeiro parâmetro é a variável A e será 
passada para a variável x. O segundo parâmetro é a variável B e será passada para a variável y. Em seguida, 
ele retorna à linha 14, atribuindo o valor retornado à variável s. Por fim, executa as linhas 15, 16 e 17 eo 
programa é encerrado. 


8.2.6 Function com passagem de parâmetros por referência 


Uma function pode receber parâmetros no momento em que é chamada. Os valores informados são 
copiados, sequencialmente, em variáveis descritas em seu cabeçalho. A sintaxe correta é a seguinte: 


FUNCTION nome da function(VAR parâmetros:tipo dos dados) :tipo de dado do valor retornado; 
declaração de variáveis locais; 
BEGIN 
comandos ; 
END; 


A chamada a uma function acontece atribuindo seu nome a uma variável ou a uma condição, que 
receberá o retorno ao término de sua execução. No momento da chamada, são informados, também, os 
parâmetros que deverão ser levados para a function. A seguir, é apresentado um exemplo de function com 
passagem de parâmetros por referência, ou seja, os parâmetros se comportam como variáveis globais (a 
numeração das linhas não faz parte do programa). 


Lo PROGRAM EXEMPLO; 

Ps USES CRT; 

BR VAR A, B, S : INTEGER; (variáveis globais) 
4. FUNCTION SOMAR(VAR X,Y: INTEGER): INTEGER; 
5. BEGIN 

6 

7 


8. BEGIN {início do programa principal} 
9. CLRSCR; 
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10. WRITELN('Digite o primeiro número: '); 

Lilo READLN(A); 

12. WRITELN('Digite o segundo número: '); 

13. READLN(B); 

14. S := SOMAR(A,B); {chamada da sub-rotina SOMAR) 
T53 WRITELN('Soma = ʻ,S); 

16. READLN; 

17. END. 


O programa começa sua execução no BEGIN principal, representado no exemplo anterior pela linha 
8. Posteriormente, executa as linhas 9 a 14. Na linha 14, existe a chamada a uma function. O programa 
principal é desviado para a function, denominada somar. Assim, o fluxo de execução do programa vai para 
a linha 4, executando toda a function, ou seja, da linha 4 à 7. O primeiro parâmetro é a variável A e será 
passada para a variável x. O segundo parâmetro é a variável B e será passada para a variável y. Como os 
parâmetros foram passados por referência e isso é identificado pela presença da palavra var no cabeçalho 
da function, qualquer alteração nos valores de x ou de y será também refletida nas variáveis A e B, respec- 
tivamente. Em seguida, ele retorna à linha 14, atribuindo o valor retornado à variável s. Por fim, executa 
as linhas 15, 16 e 17 e o programa é encerrado. 


8.2.7 Units 


Uma unit é um arquivo (.PAS), que pode conter várias procedures e functions, e, depois de compilado, 
torna-se uma biblioteca (.TPU), que pode ser chamada por outros programas por meio do comando USES. 
À sintaxe de uma unit é a seguinte. 


UNIT nome da unit; {o nome da unit deve ser o nome do arquivos 
INTERFACE 
Cabeçalho das procedures e das functions; 
IMPLEMENTATION 
Implementação das procedures e das functions; 
END; 


Exemplo de unit: 


unit calcula; {esse arquivo deve ser salvo como CALCULA. PAS) 
interface 

procedure somar(a,b: integer); 

function multiplicar(a,b,c: integer): integer; 
implementation 

procedure somar(a,b: integer); 

var s: integer; 

begin 

s:=a+b; 

writeln('Soma = ',s); 

end; 

function multiplicar(a,b,c:integer):integer; 

begin 

multiplicar := a * b * c}; 

end; 
end. 


Para criar uma unit, ou seja, uma biblioteca, é necessário abrir um novo arquivo, digitar os códigos 
da biblioteca, como mostra o exemplo anterior, e salvar o arquivo com o mesmo nome da unit. Esse 
arquivo será .PAS. Em seguida, no menu COMPILE, altere o destino da compilação para DISK. Assim, 
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depois que a unit for compilada e não apresentar mais erros, será gerado o arquivo .TPU que é a biblio- 
teca propriamente dita. 


Exemplo de programa que utiliza uma unit (biblioteca): 


program sub rotina; 


uses crt, calcula; (utilização das bibliotecas CRT e CALCULA) 
var x,y,Z mult: integer; (variáveis globais) 

begin 

ciirscr 


writeln('Digite o valor de x'); 

readlin(x); 

writeln('Digite o valor de y'); 

readin(y); 

{chamada da sub-rotina SOMAR que está na biblioteca calcula) 
somar (x,y); 

writeln('Digite o valor de z'); 

readlin(z); 

{chamada da sub-rotina MULTIPLICAR que está na biblioteca calcula) 
mult:=multiplicar(x,y,2Z); 

writeln('Multiplicação = ',mult); 

readln; 

end. 


8.3 Sub-rotinas em C/C++ (funções) 


Um importante recurso apresentado nas linguagens de programação é a modularização, na qual um 
programa pode ser particionado em sub-rotinas bastante específicas. A linguagem C/C++ possibilita a mo- 
dularização por meio de funções. 

Um programa escrito na linguagem C/C++ tem, no mínimo, uma função chamada main, por onde a 
execução começa. Existem também muitas outras funções predefinidas na linguagem C/C++, por exemplo: 
ceil(), stremp(), strcpy() etc. Essas funções são adicionadas aos programas pela diretiva ginclude, 
no momento da “linkedição”. 

Além disso, o usuário também pode criar quantas funções quiser, dependendo do problema que estiver 
sendo resolvido pelo programa. As funções às vezes precisam receber valores externos, chamados parâme- 
tros, e também podem devolver algum valor produzido para o ambiente externo, denominado retorno. 

Os parâmetros são representados por uma lista de variáveis colocadas dentro de parênteses, logo após 
o nome da função. Caso haja retorno, a última linha da função deverá incluir o comando return, seguido 
do valor ou variável que será devolvido a quem chamou a função. O tipo do valor retornado deverá ser 
exatamente igual ao tipo informado antes do nome da função. Caso não haja retorno, o tipo informado 
antes do nome da função será void. Os tipos de funções são apresentados em detalhes a seguir. 

As variáveis globais, ou seja, reconhecidas por todas as partes do programa, devem ser de- 
claradas fora de todas as funções, inclusive fora da função main. As variáveis locais devem ser 
declaradas dentro das sub-rotinas e são reconhecidas apenas na sub-rotina onde foram declaradas. 

A seguir, um programa exemplo, que soma dois números digitados pelo usuário, será utilizado para 
demonstrar os diferentes tipos de sub-rotinas. 


8.3.1 Funções sem passagem de parâmetros e sem retorno 


O tipo mais simples de função é aquele que não recebe nenhuma informação no momento de sua cha- 
mada e que também não repassa nenhum valor para quem a chamou. A seguir, é apresentado um exemplo 
de função sem parâmetros e sem retorno (a numeração das linhas não faz parte do programa) com a utili- 
zação de variáveis globais. 
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lo include <stdio.h> 

2: rnt a, b, s; // variáveis globais 

So void soma() 

4. { 

Do printf(“AnDigite o primeiro número: “); 
6. scanf(“Sd$%*c”,&a); 

To printf(“AnDigite o segundo número: “); 
8. scanf (“3d%*c”,&b); 

9. s=a+b; 

10. printf(“inSoma = %d",s); 

ilikas } 

12. int main() 

T3: { 

14. soma (); 

ão getchar(); 

16. return 0; 

7 } 


Como já comentado na seção 8.3, a execução de programa escrito em C/C++ sempre começa pela fun- 
ção main. No exemplo, a execução se inicia na linha 12. Na linha 14, existe uma chamada à função soma. 
Nesse ponto, o fluxo da execução é desviado para a linha 3. Depois, são executadas as linhas 4 até 11. 
Quando a execução atinge a linha 11, a marca de final da função é encontrada. Nesse momento, o fluxo 
da execução retorna para a linha 15, exatamente abaixo de onde ocorreu o desvio para a função soma. Na 
linha 17 está a marca de finalização da função main. Assim, a execução do programa é concluída. 

Devemos destacar que, no momento em que a função soma foi chamada, na linha 14, nenhum valor 
ou variável foi colocado entre parênteses, indicando que não houve passagem de parâmetros. Além disso, 
dentro da função soma não foi utilizado o comando return, sinalizando que ela não retornou valor para 
quem a chamou. Por essa razão, seu tipo é void. 

A seguir, é apresentado um exemplo de função sem parâmetros e sem retorno (a numeração das linhas 
não faz parte do programa) com a utilização de variáveis locais. 


ibe #include <stdio.h> 

DES void soma() 

3. { 

4. inte a, bDi s7 // variáveis locais da sub-rotina soma 
Do printf(“InDigite o primeiro número: “); 
6. scanf(“Sd$*c”,&a); 

To printf(“InDigite o segundo número: “); 
8. scanf(“$d$*c”,&b); 

9. s=a+b; 

10. printf(“inSoma = 3d”,s); 

its 3) 

12. int main() 

So 4 

14. soma(); 

EST getchar(); 

16. return 0; 

o 3 


No exemplo anterior, a execução se inicia na linha 12. Na linha 14, existe uma chamada à função soma. 
Nesse ponto, o fluxo da execução é desviado para a linha 2. Depois, são executadas as linhas 2 até 11. 
Quando a execução atinge a linha 11, a marca de final da função é encontrada. Nesse momento, o fluxo 
da execução retorna para a linha 15, exatamente abaixo de onde ocorreu o desvio para a função soma. Na 
linha 17 está a marca de finalização da função main. Assim, a execução do programa é concluída. 
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8.3.2 Funções com passagem de parâmetros e sem retorno 


O segundo tipo de função é representado por aquelas que recebem valores no momento em que são 
chamadas (parâmetros), mas que, no final, não devolvem valor para quem as chamou (retorno). A seguir, é 
mostrado um exemplo (a numeração das linhas não faz parte do programa, servindo apenas para facilitar 
a explicação). 


1. include <stdio.h> 

Zo void soma(int a, int b) 

So { 

an int s; // variável local da sub-rotina soma 
Do Ss = e ar lop 

6. printf(“inSoma = %d",s); 

a } 

8. int main() 

Sia { 

10. alimãe E Joyp // variáveis locais da sub-rotina main 
FIS printf(“\nDigite o primeiro número: “); 

12. scanf (“Sd%*c”,&a); 

13 printf(“AnDigite o segundo número: “); 

14. scanf (“$d%*c”,&b); 

5: soma(a,b); 

16. getchar(); 

TAS return 0; 

18. } 


No exemplo anterior, a execução se inicia na linha 8 e as linhas 9 a 15 são executadas. Na linha 15, 
existe uma chamada à função soma. Nesse ponto, o fluxo da execução é desviado para a linha 2. Depois, 
são executadas as linhas 2 até 7. Quando a execução atinge a linha 7, a marca de final da função é encon- 
trada. Nesse momento, o fluxo da execução retorna para a linha 16, exatamente abaixo de onde ocorreu o 
desvio para a função soma. Na linha 18 está a marca de finalização da função main. Assim, a execução do 
programa é concluída. 

Devemos destacar que, no momento em que a função soma foi chamada, na linha 15, duas variáveis fo- 
ram colocadas entre parênteses, indicando que houve passagem de parâmetros. Os valores dessas variáveis 
são copiados para as variáveis a e b, descritas no cabeçalho da função, na linha 2, sendo assim variáveis 
locais da função soma. Além disso, dentro da função soma não foi utilizado o comando return, indicando 
que ela não retornou valor para quem a chamou. Por essa razão, seu tipo foi definido como void. 


8.3.3 Funções sem passagem de parâmetros e com retorno 


O terceiro tipo de função é representado por aquelas que não recebem valores no momento em que são 
chamadas (parâmetros), mas que, no final, devolvem um valor para quem as chamou (retorno). A seguir, é 
apresentado um exemplo (a numeração das linhas não faz parte do programa, servindo apenas para facilitar 
a explicação). 


I #include <stdio.h> 

Dio int soma() 

Sa { 

4. int a, Db, s; // variáveis locais da sub-rotina soma 
Do printf(“AnDigite o primeiro número: “”); 

6. scanf (“2Sd3$*c”,&a); 

Te printf (“AnDigite o segundo número: “); 

8. scanf (“2Sd3$*c”,&b); 

So s=a+b; 

10. return s; // retorno da sub-rotina soma 
AL a } 
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12. int main() 

13 { 

14. int s; // variável local da sub-rotina main 
SP s = soma(); // chamada da sub-rotina soma 

16. printf(“inSoma = %d",s); 

17. getchar(); 

18. return 0; 

19. } 


No exemplo anterior, a execução se inicia na linha 12 e as linhas 13 a 15 são executadas. Na li- 
nha 15, existe uma chamada à função soma. Nesse ponto, o fluxo da execução é desviado para 
a linha 2. Depois, são executadas as linhas 2 até 10. Quando a execução atinge a linha 10, a marca de 
retorno da função é encontrada. Nesse momento, o fluxo da execução retorna para a linha 15, atribuindo 
o valor retornado à variável s. Por fim, executa as linhas 16 a 19. Na linha 19 está a marca de finalização 
da função main. Assim, a execução do programa é concluída. 

Devemos destacar que, no momento em que a função soma foi chamada, na linha 15, nenhum valor 
ou variável foi colocado entre parênteses, o que indica que não houve passagem de parâmetros. Além 
disso, dentro da função soma, foi utilizado o comando return s, significando que o valor da variável s 
foi devolvido a quem a chamou. Por essa razão, o tipo da função é int, exatamente igual ao tipo do valor 
retornado. 


8.3.4 Funções com passagem de parâmetros e com retorno 


O quarto tipo de função é representado por aquelas que recebem valores no momento em que são 
chamadas (parâmetros) e que, no final, devolvem um valor para quem as chamou (retorno). A seguir, é 
apresentado um exemplo (a numeração das linhas não faz parte do programa, servindo apenas para fa- 
cilitar a explicação). 


I #include <stdio.h> 

2. int soma(int a, int b) 

Do { 

4. return a + b; 

Do } 

6. int main() 

o { 

8. inte a D S7 

So printf(“NAnDigite o primeiro número: “); 
10. scanf(“Sd%*c”,&a); 

FIS printf(“AnDigite o segundo número: “); 
12. scanf (“3$d%*c”,&b); 

Io s = soma(a,b); 

14. printf(“inSoma = 2d",s); 

15: getchar(); 

16. return 0; 

17 } 


No exemplo anterior, a execução iniciou na linha 6. A partir daí, são executadas sequencialmente as 
linhas 7 a 13. Nas linhas 10 e 12, dois valores são recebidos e armazenados nas variáveis a e b. Chegando 
à linha 13, o fluxo de execução é desviado para a função soma, levando para lá os valores das variáveis 
a e b. Serão, então, executadas as linhas 2 a 4. Ao chegar à linha 4, o comando return é encontrado. 
Isso indica que a execução da função chegou ao fim e que o valor da operação a + b será devolvido para 
quem a chamou. O fluxo de execução retorna à função main, na linha 13, e o valor retornado é atribuído 
à variável s. Depois disso, as linhas 14 a 17 são executadas e o programa chega ao fim. 

Devemos destacar que, no momento em que a função soma foi chamada, na linha 13, duas variáveis 
foram colocadas entre parênteses, indicando que houve passagem de parâmetros. Assim, os valores dessas 
variáveis são copiados, respectivamente, para as variáveis a e b, descritas no cabeçalho da função, na li- 
nha 2. Além disso, dentro da função soma foi utilizado o comando return a + b, sinalizando que o valor 
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da operação a + b será devolvido a quem a chamou. Por essa razão, o tipo da função é exatamente igual 
ao tipo do valor retornado, ou seja, int. 


see Observação 


Em qualquer programa, podemos escrever funções antes ou depois da função main. Se op- 
tarmos por escrevê-las antes, nenhum cuidado especial será necessário. Porém, se optarmos por 
escrevê-las abaixo da função main, deveremos fazer uso dos protótipos de função. Protótipo de 
uma função é uma linha exatamente igual ao cabeçalho da função (terminando com um ponto 
e vírgula) que sempre deverá ser escrita antes da função main. Essa linha é responsável por in- 
formar ao compilador quais outras funções serão encontradas ao término da main. Observe o 
exemplo a seguir. 


Lg include <stdio.h> 

2 int soma(int a, int b); // esta linha descreve o protótipo da função 
3 int main() 

4. { 

Do int a, b, s; 

6 printf(“NnDigite o primeiro número: “); 
7 scanf (“3Sd%*c”,&a); 

8. printf(“AnDigite o segundo número: “); 
9. scanf(“Sd$*c”,&b); 

10. s = soma(a,b); 

Tila printf(“inSoma = 2d”",s); 

12. getchar(); 

Se. return 0; 

14. } 

Mão int soma(int a, int b) 

16. { 

aye return a + b; 

18. } 


8.3.5 Passagem de parâmetros por valor 


Passagem de parâmetros por valor significa que a função trabalhará com cópias dos valores passados 
no momento de sua chamada. Para entender melhor esse processo, observe o programa a seguir (a numera- 
ção das linhas não faz parte do programa, servindo apenas para facilitar a explicação). 


1. #include <stdio.h> 

2. int soma dobro(int a, int b); 

3. int main() 

4.4 

ão alihe, Sé 7 ISS 

6. printf(“AnDigite o primeiro número: “); 
Ts scanf (“Sd3$*c”,&x); 

8. printf(“iAnDigite o segundo número: “); 
9. scanf (“3Sd3*Cc”,&y); 

10. res = soma dobro(x,y); 

11. printf(“inA soma do dobro dos números $d e %d = 3d” ,x,y,res); 
12. getchar(); 

T3: return 0; 

14. } 


15. int soma_dobro(int a, int b) 
16. { 
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7 int soma; 
18. a=2*a; 
19. D= 2k D 


20. soma = a + b; 
ZON es return soma; 
Bo | 


Na Figura 8.1 é feita uma representação gráfica de como se dá uma passagem de parâmetros por valor, 
apresentada no programa anterior. Estamos supondo que os valores armazenados nas variáveis x e y, por 
meio da execução das linhas 7 e 9, tenham sido, respectivamente, 5 e 3. Quando a linha 10 é executada, 
esses valores são copiados para as variáveis a e b (pertencentes à função soma dobro). Depois disso, os 
valores de a e b são multiplicados por 2, nas linhas 18 e 19, e depois, na linha 20, é realizada a soma. O 
resultado dessa soma é devolvido à função main pela execução da linha 21, onde o valor calculado recai 
sobre a variável res (retorno à linha 10). 


Figura 8.1 Representação gráfica da passagem de parâmetros por valor. 


Função main Função soma dobro 
res = soma dobro (5,3) 
x E > a 5 5*2 = 10 
y > b E 32=6 
res 16 soma) 16 


se MM return soma 


No momento em que a função soma dobro chega ao fim, as variáveis a, b e soma são destruídas e, 
portanto, as alterações realizadas pelas multiplicações por 2 são perdidas, ou seja, x continua valendo 5 e 
y continua valendo 3. 


8.3.6 Passagem de parâmetros por referência 


Passagem de parâmetros por referência significa que os parâmetros passados para uma função cor- 
respondem a endereços de memória ocupados por variáveis. Dessa maneira, toda vez que for necessário 
acessar determinado valor, isso será feito por meio de referência, ou seja, apontamento ao seu endereço. 


include <stdio.h> 

int soma dobro(int *a, int *b); 

int main() 

{ 

int x, y, res; 

printf(“NAnDigite o primeiro número: “); 
scanf (“3Sd%*c”,&x); 

printf(“AnDigite o segundo número: “); 
scanf (“3Sd%*c”,&y); 

res = soma dobro(&x,&y); 


o JIJ A UMa UN 


Yo) 


HAHAHAH 
ON UU EB wUNHO sos 
Pe, RA a 


printf(“inA soma dos números %d e %d = %d”,x,y,res); 
getchar(); 

return 0; 

} 

int soma_dobro(int *a, int *b) 

{ 

int soma; 

ža = 2*(*a); 


HH 
co 
. . 
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19. žb = 2*(*b); 
20. soma = *a + *b; 
2an return soma; 
22. } 


A Figura 8.2 representa graficamente o que acontece durante a execução do programa apresentado, 
onde ocorre a passagem de parâmetros por referência à função soma_dobro. 

Nas linhas 7 e 9 são lidos, respectivamente, os valores para as variáveis x e y (como exemplo, supomos 
que tenham sido digitados os valores 5 e 3). Entretanto, quando a função soma dobro é chamada, na linha 
10, são passados como parâmetros para a função os endereços de memória ocupados pelas variáveis x e y 
(isso é feito pelo operador & que obtém o endereço de memória de uma variável), ou seja, pelo nosso exem- 
plo, os valores 800 (endereço ocupado por x) e 300 (endereço ocupado por y). Dessa maneira, os valores 
que recaem sobre as variáveis a e b (da função) são, respectivamente, 800 e 300 (isso é correto, uma vez que 
a e b são ponteiros para int). 

Nas linhas 18 e 19, os valores 5 e 3 são multiplicados por 2. Nesse momento, ocorre a “referência” 
aos endereços de memória 800 e 300, para que sejam obtidos os valores iniciais e, após a realização das 
multiplicações, os valores sejam alterados. Dessa forma, no endereço 800 passamos a ter o valor 10, e no 
endereço 300 passamos a ter o valor 6. Na linha 20, é realizada a soma dos valores que estão nos endere- 
ços especificados por a e b (que já foram multiplicados por 2). Por fim, na linha 21, o resultado da soma 
é devolvido à função main, recaindo sobre a variável res (linha 10) e encerrando a função soma dobro. 

Quando a função soma dobro chega ao fim, as variáveis a, b e soma são destruídas. Entretanto, as al- 
terações decorrentes das multiplicações feitas são mantidas, pois cada alteração fez referência a endereços 
de memória que estavam fora da área destinada à função. Assim, após a função soma dobro, o valor de x 
será 10 e o de y será 6. 


Figura 8.22 Representação gráfica da passagem de parâmetros por referência. 


Função main 10 Função soma dobro 
x 5 =. 
800 a 1800 | a=a?2 
y 3 b Koo BEIRA 
300 


res 16 soma 16 


S return soma 


QQQ Observação 


A linguagem C/C++ não permite que vetores e matrizes sejam passados na íntegra como 
parâmetro para uma função. Para resolver esse problema, deve-se passar apenas o endereço da 
posição inicial do vetor ou da matriz. Esse endereço é obtido utilizando-se o nome do vetor (ou 
da matriz) sem o índice entre colchetes. Isso quer dizer que é possível passar um vetor para uma 
função somente se essa passagem for por referência. Observe o exemplo (a numeração das linhas 
não faz parte do programa, servindo apenas para facilitar a explicação). 


1. #include <stdio.h> 
2. void soma_linhas(float m[][5], float v[]) 
Dae 
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Co aghe Sp SIP 

Do stop (4 S Op < Sica) 
6. { 

7. for (J = 0;j < 5;j++) 
8. { 

9. vli] = v[i] + m[i][j]; 
10. } 

IRA s 

12.) 

13.int main() 

14.14 


US ame ao IP 

16. float mat[3][5], vet[3]; 
ho ogos (a = (Opa < Salas) 
18. { 

19. vet[i] = 0; 

2 Efor (5) = (045) S 57E) 


21. { 

22. printf(“AnDigite o elemento %d - 3d:",i,5J); 
DI scanf(“Sf3$*c”,&mat[1][5]); 

24. } 

25. } 


26.soma_linhas (mat, vet); 

27.for (i = 0;i < 3,i++) 

28.1 

29. printf(“inSoma da linha %d = 3f”,i,vet[il); 
30.) 

31.getchar(); 

32.return 0; 

33.) 


A execução desse programa começa na linha 13, com a função main. Na função main, são declaradas 
algumas variáveis, dentre elas, mat e vet. À variável mat representa uma matriz bidimensional com 3 linhas e 
5 colunas para armazenar números reais. A variável vet representa um vetor com 3 posições para armazenar 
a soma dos números de cada linha da matriz mat. Da linha 17 à 25, a matriz mat é preenchida com números 
inseridos pelo usuário. Aproveitando essas estruturas de repetição, o vetor vet tem todas as suas posições 
inicializadas com zero, na linha 19. 

Duas linhas merecem atenção especial: 26 e 2. A linha 26 está chamando a função soma linhas, pas- 
sando como parâmetros a matriz mat e o vetor vet. Observe, entretanto, que essas duas variáveis não estão 
acompanhadas de colchetes ([1). Assim, quando o nome de uma matriz ou vetor for utilizado sem apresen- 
tar colchetes contendo um índice, isso significa que estamos usando o endereço de memória ocupado pela 
posição O do vetor ou pela posição 0X0 da matriz. 

Como endereços de memória só podem ser atribuídos a ponteiros, observe a linha 2, onde está o ca- 
beçalho da função soma linhas. Nela, pode-se ver que a função recebe dois parâmetros: m[][5] e v[]. 
Assim, toda vez que encontrar um vetor com colchetes vazios ou uma matriz com os colchetes da primeira 
dimensão vazios, entenda que eles são variáveis ponteiros que guardam os endereços iniciais das variáveis. 

A partir daí, o programa consegue percorrer o vetor e a matriz normalmente, da linha 5 à 11. Quando 
a função soma linhas chegar ao fim, o fluxo de execução retornará para a linha 27 e o vetor vet, que 
entrou na função soma linhas contendo zero em todas as suas posições, voltará com o somatório dos nú- 
meros de cada linha da matriz mat. Esses valores serão mostrados nas linhas 27 à 29. O programa, então, 
é finalizado. 
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8.3.7 Sub-rotinas em arquivos separados (bibliotecas) 


Na linguagem C/C++ existem algumas bibliotecas já implementadas e dentro destas existem inúmeras 
funções. Por exemplo, na biblioteca stdio.nh, existem as funções scanf, getchar, printf, entre outras. 
Assim, nesta seção, discutiremos a possibilidade de criar bibliotecas próprias com uma ou várias funções. 

Para criar uma biblioteca é necessário gerar um novo arquivo e dentro dele pôr o código de todas as 
funções que farão parte dessa biblioteca. Esse arquivo deve ser salvo com extensão .h e deve ser compilado 
normalmente. 

O exemplo a seguir é uma biblioteca denominada rotinas.h e possui três sub-rotinas. 


include <stdio.h> 
void sub rotinal() 


{ 
printf (“mostrando uma mensangem” ); 
dy 
void sub rotina2Z() 
{ 
int a,b,c; 
printf(“Digite o valor de a: “); 
scanf(“Sd$%*c”,&a); 
printf(“Digite o valor de b: “); 
scanf (“3$d%*c”,&b); 
c= a- b; 
printf(“Resultado = %d”,c); 
} 
int sub rotina3(int x,int y) 
{ 
int res; 
res = X * y; 
return res; 
} 


O código a seguir mostra um programa que faz uso da biblioteca criada anteriormente. 


ls include <stdio.h> 

2% #include “c:\teste\rotinas.h” 
So int main() 

4. { 

55 int numl, num2, res; 

6. sub rotinal(); 

Ta sub_rotina2(); 

8. printf(“Digite um número: “); 
9 scanf(“s$d$*c”, &numl); 

10. printf(“Digite outro número: “); 
JUL scanf (“2Sd%*c”, &num2) ; 

12. res = sub rotina3(numl, num2); 
Wea printf (“resultado = 2%d”,res); 
14. getchar(); 

sa return 0; 

16. } 


Quando uma nova biblioteca for utilizada em um programa e seu arquivo estiver salvo no diretório- 
-padrão das bibliotecas da linguagem C/C++, basta chamá-la por meio da diretiva #include <biblioteca. 
h>. Quando a nova biblioteca está em outro diretório, sua chamada deve obedecer à seguinte sintaxe: #in- 
clude “caminhoYnome da biblioteca.h”, como mostra a linha 2 do código dado anteriormente. 
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8.4 Sub-rotinas em JAVA (métodos) 


JAVA é uma linguagem que dá suporte ao paradigma orientado a objeto. Assim, todos os programas 
devem fazer uso de classes. Uma classe pode ser entendida como um tipo de dado capaz de armazenar di- 
versas informações e também várias funções para manipular adequadamente essas informações. Seguindo o 
paradigma orientado a objetos, essas informações são chamadas atributos, e as funções, métodos. 

Como acontece com todas as linguagens de programação, o usuário poderá utilizar métodos de classes 
já existentes (o Capítulo 9 abordará, por exemplo, vários métodos especificamente criados para trabalhar 
com cadeias de caracteres), como também poderá criar quantos métodos forem necessários para a resolução 
do problema. O capítulo 12 apresenta uma introdução à programação orientada a objetos. 

Cada método pode receber diversos valores, os parâmetros, e pode devolver um valor, o retorno. Dessa 
maneira, quando se especifica um método, deve-se deixar claro qual será o tipo de retorno e quais são os 
parâmetros necessários para a sua execução. A chamada a um método normalmente requer que seja infor- 
mado o objeto ou a classe que o executará. À sintaxe para chamada de um método é apresentada a seguir. 


[retorno = ]nomeDoObjeto.nomeDoMétodo( [ listaDeParametros ]); 
ou 
[retorno = ]JnomeDaClasse.nomeDoMétodo([ listaDeParametros ]); 


Observe que o retorno e a listaDeParametros aparecem entre colchetes, indicando que são opcionais. 

A seguir, são apresentados vários exemplos de métodos. É importante observar que, em todos eles, apa- 
recerão as palavras public e static. Essas palavras são chamadas modificadores, ou seja, definem caracte- 
rísticas complementares aos métodos. Outros modificadores são: private, protected, abstract e final. 

O modificador public quer dizer que o método poderá ser chamado por qualquer classe, e o modifi- 
cador static indica que esse método existirá e poderá ser executado mesmo se nenhum objeto da classe 
onde estiver inserido for criado. 

Os parâmetros são representados por uma lista de variáveis colocadas dentro de parênteses, logo após 
o nome do método. Caso haja retorno, a última linha do método deverá incluir o comando return, seguido 
do valor ou variável que será devolvido a quem chamou o método. O tipo do valor retornado deverá ser 
exatamente igual ao tipo informado antes do nome do método. Caso não haja retorno, deverá ser digitada 
a palavra void. Os tipos de métodos são apresentados em detalhes a seguir. 

As variáveis globais, ou seja, aquelas que são reconhecidas por todas as partes do programa, devem ser 
declaradas fora de todos os métodos, inclusive fora do método main. As variáveis locais devem ser declara- 
das dentro dos métodos e são reconhecidas apenas no método onde foram declaradas. 

A seguir, um programa exemplo que soma dois números digitados pelo usuário será utilizado para 
demonstrar os diferentes tipos de métodos. 


8.4.1 Métodos sem passagem de parâmetros e sem retorno 


O tipo mais simples de método é aquele que não recebe nenhuma informação no momento de sua 
chamada e também não repassa nenhum valor para quem o chamou. À seguir, é apresentado um exemplo 
de método sem parâmetros e sem retorno (a numeração das linhas não faz parte do programa) com a 
utilização de variáveis globais. 


1. import java.util.Scanner; 

2. public class Exemplo 

Do { 

4. static int a, b, s; // variáveis globais 
57 public static void main(String args[]) 

6. { 

da soma (); // chamada do método soma() 
8. } 

9. public static void soma() 

10. { 

11. Scanner e = new Scanner(System.in); 


12. System.out.println(“Digite o primeiro número: “); 
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so a = e.nextInt(); 

Tan System.out.println(“Digite o segundo número: “); 
Io b = e.nextInt(); 

16. Sb = El ap loop 

Wo System.out.println(“Soma = “ + s); 

18. } 

19. } 


Como acontece nos programas escritos na linguagem C/C++, a execução de um programa JAVA tam- 
bém começa pelo método main. No exemplo, a execução iniciou na linha 5. Na linha 7, existe uma chamada 
ao método soma. Nesse ponto, o fluxo da execução é desviado para a linha 9. Depois, são executadas as 
linhas 10 a 18. Quando a execução atingir a linha 18, a marca de final de método será encontrada. Nesse 
momento, o fluxo da execução retorna para a linha 8, exatamente abaixo de onde ocorreu o desvio para o 
método. Nessa linha está a marca de finalização do método main. Desse modo, a execução do programa é 
concluída. 

Devemos destacar que, no momento em que o método soma foi chamado, na linha 7, nenhum valor ou 
variável foi colocado entre parênteses, o que indica que não houve passagem de parâmetros. Além disso, 
dentro do método soma não foi utilizado o comando return, sinalizando que ele não retornou valor para 
quem o chamou. Por essa razão, seu tipo é void. 

A seguir, é apresentado um exemplo de método sem parâmetros e sem retorno (a numeração das linhas 
não faz parte do programa) com a utilização de variáveis locais. 


1. import java.util.Scanner; 

2. public class Exemplo 

Sa e 

4. public static void main(String args[]) 

5. { 

6. soma (); // chamada do método soma() 
7. } 

8. public static void soma() 

9. { 

10. ine ar br S7 // variáveis locais 

AL o Scanner e = new Scanner (System. in); 

12. System.out.println(“Digite o primeiro número: “); 
3 a = e.nextInt(); 

14. System.out.println(“Digite o segundo número: “); 
Io b = e.nextInt(); 

16. s=a+b; 

17. System.out.println(“Soma = “ + s); 

18. } 

19, 3 


No exemplo anterior, a execução iniciou na linha 4. Na linha 6, existe uma chamada ao método soma. 
Nesse ponto, o fluxo da execução é desviado para a linha 8. Depois, são executadas as linhas 9 a 17. Quan- 
do a execução atingir a linha 18, a marca de final de método será encontrada. Nesse momento, o fluxo da 
execução retorna para a linha 7, exatamente abaixo de onde ocorreu o desvio para o método. Nessa linha 
está a marca de finalização do método main. Desse modo, a execução do programa é concluída. 

Devemos destacar que, no momento em que o método soma foi chamado, na linha 6, nenhum valor ou 
variável foi colocado entre parênteses, o que indica que não houve passagem de parâmetros. Além disso, 
dentro do método soma não foi utilizado o comando return, sinalizando que ele não retornou valor para 
quem o chamou. Por essa razão, seu tipo é void. 
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8.4.2 Métodos com passagem de parâmetros e sem retorno 


O segundo tipo de método é representado por aqueles que recebem valores no momento em que são 
chamados (parâmetros), mas que, no final, não devolvem valor para quem os chamou (retorno). A seguir, é 
apresentado um exemplo (a numeração das linhas não faz parte do programa, servindo apenas para facilitar 
a explicação). 


1. import java.util.Scanner; 

2. public class Exemplo 

3. + 

4. public static void main(String args[]) 

Do { 

6 int a, b; // variáveis locais do método main 
7 Scanner e = new Scanner (System. in); 

8 System.out.println(“Digite o primeiro número: “); 
9. a = e.nextInt(); 

10. System.out.println(“Digite o segundo número: “); 

Til +, b = e.nextInt(); 

12 soma(a,b); // chamada do método soma() 
IRS 

14 public static void soma(int a,int b) 

io A 

16. int s; // variável local do método soma() 
IL The s=a+b; 

18. System.out.println(“Soma = “ + s); 

19. } 

20. } 


Como acontece nos programas escritos na linguagem C/C++, a execução de um programa JAVA tam- 
bém começa pelo método main. No exemplo, a execução teve início na linha 4. A partir daí, são executadas 
sequencialmente as linhas 5 a 12. Nas linhas 9 e 11, dois valores são recebidos e armazenados nas variáveis 
a e b. Chegando à linha 12, o fluxo de execução é desviado para o método soma, na linha 14, levando 
para lá os valores das variáveis a e b. Serão, então, executadas as linhas 14 a 19, onde está a marca de en- 
cerramento do método. O fluxo de execução retorna ao método main, na linha 13, imediatamente abaixo 
do ponto de chamada ao método soma. Desse modo, a execução do programa é concluída. 

Devemos destacar que, no momento em que o método soma foi chamado, na linha 12, duas variáveis 
foram colocadas entre parênteses, o que significa que houve passagem de parâmetros. Os valores dessas 
variáveis são copiados para as variáveis a e b, descritas no cabeçalho do método, na linha 14. Além disso, 
dentro do método soma não foi utilizado o comando return, indicando que ele não retornou valor para 
quem o chamou. Por essa razão, seu tipo foi definido como void. 


8.4.3 Métodos sem passagem de parâmetros e com retorno 


O terceiro tipo de método é representado por aqueles que não recebem valores no momento em que são 
chamados (parâmetros), mas que, no final, devolvem um valor para quem os chamou (retorno). A seguir, é 
apresentado um exemplo (a numeração das linhas não faz parte do programa, servindo apenas para facilitar 
a explicação). 


ilo import java.util.Scanner; 

2.6 public class Exemplo 

So { 

4. public static void main(String args[]) 

Do { 

6. int s; // variável local do método main 
i 


s = soma(); // chamada do método soma() 
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8. System .out.println(“Soma = “ + s); 

9. } 

10. public static int soma() 

lilo { 

T2: tatra b, s; // variáveis locais do método soma() 
JSF Scanner e = new Scanner(System.in); 

14. System.out.println(“Digite o primeiro número: “); 
Iso a = e.nextInt(); 

16. System.out.println(“Digite o segundo número: “); 
17. b = e.nextInt(); 

18. s=a+b; 

Rom return sS; 

20. } 

21. } 


No exemplo anterior, a execução iniciou na linha 4 e, sequencialmente, as linhas 5, 6 e 7 foram execu- 
tadas. Na linha 7, existe uma chamada ao método soma. Nesse ponto, o fluxo da execução é desviado para 
a linha 10. Depois, são executadas as linhas 11 a 18. Quando a execução atingir a linha 19, o comando 
return é encontrado. Isso significa que a execução do método chegou ao fim e que o conteúdo da variável 
s será devolvido para quem o chamou. O fluxo de execução retorna ao método main, na linha 7, e o valor 
retornado é atribuído à variável s. Depois disso, as linhas 8 e 9 são executadas e o programa chega ao fim. 

Devemos destacar que, no momento em que o método soma foi chamado, na linha 7, nenhum valor 
ou variável foi colocado entre parênteses, sinalizando que não houve passagem de parâmetros. Além dis- 
so, dentro do método soma foi utilizado o comando return s, o que indica que o valor da variável s será 
devolvido a quem o chamou. Por essa razão, o tipo do método é int, exatamente igual ao tipo do valor 
retornado. 


8.4.4 Métodos com passagem de parâmetros e com retorno 


O quarto tipo de método é representado por aqueles que recebem valores no momento em que são chama- 
dos (parâmetros) e que, no final, devolvem um valor para quem os chamou (retorno). A seguir, é apresentado 
um exemplo (a numeração das linhas não faz parte do programa, servindo apenas para facilitar a explicação). 


1. import java.util.Scanner; 

2. public class Exemplo 

3. + 

4. public static void main(String args[]) 

So { 

6 dme Ap op BF // variáveis locais do método main 
7 Scanner e = new Scanner (System.in); 

8 System.out.println(“Digite o primeiro número: “); 

om a = e.nextInt(); 

10. System.out.println(“Digite o segundo número: “); 

Milo b = e.nextInt(); 

12. s = soma(a,b); // chamada do método soma() 
So System .out.println(“Soma = “ + s); 

14. 3 

15. public static int soma(int a,int b) 

So 4 

WTS return a + b; 

do 5 


19. } 
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No exemplo anterior, a execução teve início na linha 4. À partir daí, são executadas, sequencialmente, 
as linhas 5, 6, 7, 8, 9, 10 e 11. Nas linhas 9 e 11, dois valores são recebidos e armazenados nas variáveis a 
e b. Chegando à linha 12, o fluxo de execução é desviado para o método soma, levando para lá os valores 
das variáveis a e b. Serão, então, executadas as linhas 15, 16 e 17. Ao chegar à linha 17, o comando return 
é encontrado. Isso significa que a execução do método chegou ao fim e que o valor da operação a + b será 
devolvido para quem o chamou. O fluxo de execução retorna ao método main, na linha 12, e o valor retor- 
nado é atribuído à variável s. Depois disso, as linhas 13 e 14 são executadas e o programa chega ao fim. 

Devemos destacar que, no momento em que o método soma foi chamado, na linha 12, duas variáveis 
foram colocadas entre parênteses, indicando que houve passagem de parâmetros. Assim, os valores dessas 
variáveis são copiados, respectivamente, para as variáveis a e b, descritas no cabeçalho do método, na linha 
15. Além disso, dentro do método soma foi utilizado o comando return a + b, o que significa que um 
valor foi devolvido a quem o chamou. Por essa razão, o tipo do método é int, exatamente igual ao tipo do 
valor retornado. 


8.4.5 Passagem de parâmetros por valor e por referência 


Uma peculiaridade da linguagem JAVA é que todas as variáveis que não forem de tipos primitivos se- 
rão consideradas referência. Isso quer dizer que a variável contém apenas o endereço de memória onde a 
informação completa foi gravada. 

Assim, toda vez que um tipo primitivo for passado como parâmetro, essa passagem será feita por valor, 
ou seja, será criada uma cópia completa da informação dentro do método. Toda vez que um tipo não pri- 
mitivo for passado como parâmetro, a passagem será por referência, isto é, será feita uma cópia apenas do 
endereço onde a informação está gravada. As seções 8.3.5 e 8.3.6, apresentadas anteriormente, descrevem 
em detalhe esses dois tipos de passagem de parâmetros. Os princípios lá descritos são os mesmos em todas 
as linguagens de programação. 


QQQ Observação 


Na linguagem JAVA, vetores e matrizes não são considerados tipos primitivos e, assim, são 
passados como parâmetros por meio de referência. Observe o exemplo (a numeração das linhas 
não faz parte do programa, servindo apenas para facilitar a explicação). 


1. import java.util.Scanner; 

2 public class Exemplo 

3 { 

4. public static void main(String args[]) 
So { Scanner e; 

6 diwe do Sh 

7 float mat[][], vet[]; 

8. mat = new float[3][5]; 

9. vet = new float[3]; 

10. e = new Scanner(System.in); 

Mito for (i=0;i<3,i++) 

12. ft vet[i] = 0; 

Sha for (j=0;j<5;j++) 

14. { System.out.println(“Digite o elemento “ + i+“-"+5+4 2“); 
so mat[i][j] = e.nextFloat(); 

16. } 

17 o } 

18. soma_linhas(mat, vet); 

19. for (i=0; i<3; i++) 

20. { System.out.println (“Soma da linha “ + i+“ = “+ vet[i]); 
21: } 


22. } 
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23. public static void soma linhas(float m[][], float v[]) 
24. do dme do Jr 

25. for (i=0;i<3, i++) 

26. { for (j=0;j<5;j++) 

27. tov[i] = v[i]+m[illjl; 

28. } 

29. } 

30. } 

Siles } 


A execução desse programa começa na linha 4 com o método main. Nesse método, são declaradas 
algumas variáveis, dentre elas, mat e vet. A variável mat representa uma matriz bidimensional com 3 
linhas e 5 colunas para armazenar números reais. A variável vet representa um vetor com 3 posições 
para armazenar a soma dos números de cada linha da matriz mat. Da linha 11 à 17, a matriz mat é 
preenchida com números digitados pelo usuário. Aproveitando essas estruturas de repetição, o vetor 
vet tem todas as suas posições inicializadas com zero, na linha 12. 

Duas linhas merecem atenção especial, a 18 e a 23. A linha 18 está chamando o método soma | 
linhas, passando como parâmetros a matriz mat e o vetor vet. Observe, entretanto, que essas duas 
variáveis não estão acompanhadas de colchetes. Isso significa que, quando o nome de uma matriz ou 
vetor for usado sem apresentar colchetes contendo um índice, estamos usando o endereço de memória 
ocupado pela posição O do vetor ou pela posição 0X0 da matriz. 

Como endereços de memória só podem ser atribuídos a ponteiros, observe a linha 23, onde está 
o cabeçalho do método soma linhas. Nela, pode-se ver que o método está preparado para receber 
dois valores que serão atribuídos a m[][] e v[]. Assim, toda vez que encontrar um vetor e matriz 
com colchetes vazios, entenda que eles são variáveis ponteiros que guardam os endereços iniciais das 
variáveis. 

A partir daí, o programa consegue percorrer o vetor e a matriz normalmente, da linha 25 à 29. 
Quando o método soma linhas chegar ao fim, o fluxo de execução retornará à linha 19, e o vetor 
vet, que entrou no método soma linhas contendo zero em todas as suas posições, voltará com o 
somatório dos números de cada linha da matriz mat. Esses valores serão mostrados nas linhas 19 à 21. 
O programa, então, é finalizado na linha 22, quando o método main chega ao fim. 


8.4.6 Métodos em arquivos separados 


Na linguagem JAVA existe a possibilidade de criar métodos em arquivos separados do método main, o 
que torna possível a reutilização dos códigos. O exemplo a seguir é um arquivo salvo como rotinas. java 
e este foi compilado normalmente. 


import java.util.Scanner; 
public class rotinas 
{ 
public static void mensagem() 
{ 
System.out.println(“Mostra uma mensagem”); 
dy 
public static int soma() 
{ 
int a, b, c; 
Scanner dado; 
dado = new Scanner(System.in); 
System.out.println(“Digite o valor de a: “); 
a = dado.nextInt(); 
System.out.println(“Digite o valor de b: “); 
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b = dado.nextInt(); 
c=a+b; 
return c; 


O exemplo a seguir é um programa JAVA que utiliza os métodos implementados em rotinas. java, 
por isso, na primeira linha de código, existe a importação do arquivo que tem os métodos implementados. 


import sub rotinas.rotinas; 
public class principal 


{ 
public static void main(String args[]) 
{ 
E EA 
rotinas.mensagem(); 
r = rotinas.soma(); 
System.out.println(“soma = “+r); 
} 
} 


EXERCÍCIOS RESOLVIDOS 


EH Faça um programa contendo uma sub-rotina que retorne 1 se o número digitado for positivo ou O se 
for negativo. 


(AJLICIOJRN ITIM(O) SoLução: 


ALGORITMO 

DECLARE num, X NUMÉRICO 

LEIA num 

x 4 verifica(num) 

SE x = 0 

ENTÃO ESCREVA “Número positivo” 
SENÃO ESCREVA “Número negativo” 
FIM ALGORITMO. 


SUB-ROTINA verifica(num NUMÉRICO) 
DECLARE res NUMÉRICO 
SE num >= 0 
ENTÃO res — 1 
SENÃO res — 0 
RETORNE res 
FIM SUB ROTINA verifica 


PASCAL EO 
D \EXERC\CAP8\PASCAL\EX1.PAS e \EXERC\CAP8\PASCAL\EX1.EXE 


e)AeE Ra 12 SoLução: FUNÇÃO ANTES DA main() 
\EXERC\CAP8\C++\EX1_A.CPP e \EXERC\CAP8\C++\EX1_A.EXE 

22 SOLUÇÃO: FUNÇÃO DEPOIS DA main () 
\EXERC\CAP8\C++\EX1_B.CPP e \EXERC\CAP8\C++\EX1_B.EXE 
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RANMA SoLução: 
c \EXERC\CAP8\JAVA\EX1.java e \EXERC\CAP8\JAVA\EX1.class 


IFJ Faça um programa contendo uma sub-rotina que receba dois números positivos por parâmetro e re- 
torne a soma dos N números inteiros existentes entre eles. 


(ALLISIOJEN ITIMO) Solução: 


ALGORITMO 

DECLARE numl, num2, s NUMÉRICO 
LEIA numl, num2 

s « somar (numl, num2) 

ESCREVA “soma = “, s 

FIM ALGORITMO. 


SUB-ROTINA somar (numl, num2 NUMÉRICO) 
DECLARE i, s NUMÉRICO 


SERÃO 
PARA i < numl+1 ATÉ num2-1 FAÇA 
INÍCIO 
S- + 
FIM 
RETORNE s 


FIM SUB ROTINA somar 


PASCAL, [Sono to 
(EE \EXERC\CAP8\PASCAL\EX2.PAS e \EXERC\CAP8\PASCAL\EX2.EXE 


C/C++ ta SoLução: FUNÇÃO ANTES DA main() 
D \EXERC\CAP8\C++\EX2_A.CPP e \EXERC\CAP8\C++\EX2_A.EXE 


22 SOLUÇÃO: FUNÇÃO DEPOIS DA main () 


\EXERC\CAP8\C++\EX2_B.CPP e \EXERC\CAP8\C++\EX2_B.EXE 


RB WIA NA SoLução: 
a \EXERC\CAP8\java\EX2.java e \EXERC\CAP8\JAVA\EX2.class 


IEJ Faça um programa contendo uma sub-rotina que receba três números inteiros a, b e c, sendo a maior 
que 1. A sub-rotina deverá somar todos os inteiros entre b e c que sejam divisíveis por a (inclusive b e 
c) e retornar o resultado para ser impresso. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE a, b, c, result NUMÉRICO 
REPITA 
LEIA a 
ATÉ a>l 
LEIA b,c 
result + divisores(a, b, c) 
ESCREVA “Soma dos inteiros = “, result 
FIM_ALGORITMO. 
SUB-ROTINA divisores(a, b, c NUMÉRICO) 
DECLARE i, s, r NUMÉRICO 
a = 0 
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PARA i — b ATÉ c FAÇA 


INÍCIO 
r — RESTO (i / a) 
SE r = 0 
ENTÃO s — s+i 
FIM 
RETORNE s 


FIM SUB ROTINA divisores 


PASCAL SOLUÇÃO: 
E \EXERC\CAP8\PASCAL\EX3.PAS e \EXERC\CAP8\PASCAL\EX3.EXE 


e)AeR TSA 12 SoLUÇÃO: FUNÇÃO ANTES DA main() 
GEE \EXERC\CAP8\C++\EX3_A.CPP e NEXERCICAP8ICHEX3 A. EXE 


22 SOLUÇÃO: FUNÇÃO DEPOIS DA main() 
\EXERC\CAP8\C++\EX3_B.CPP e \EXERC\CAP8\C++\EX3_B.EXE 


RB WIA NA SoLução: 
EEE) VEXERCICAP8AJAVANEX3. java e \EXERC\CAP8\JAVA\EX3.class 


EA Faça uma sub-rotina que receba um único valor representando segundos. Essa sub-rotina deverá con- 
vertê-lo para horas, minutos e segundos. Todas as variáveis devem ser passadas como parâmetro, não 
havendo variáveis globais. 


(AJLIGJOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE seg NUMÉRICO 

LEIA seg 

transformacao (seg); 

FIM ALGORITMO. 

SUB-ROTINA transformacao( segundos NUMÉRICO) 
DECLARE h, m, Ss, E NUMÉRICO 
h — segundos / 3600 
r + RESTO(segundos / 3600) 
m< r / 60 
s = RESTO(r / 60) 

ESCREVA h, m, Ss 
FIM SUB ROTINA transformacao 


PASCAL SOLUÇÃO: 
SME \EXERC\CAP8\PASCAL\EX4.PAS e \EXERC\CAP8\PASCAL\EX4. EXE 


C/C++ 1a SoLução: FUNÇÃO ANTES DA main() 
\EXERC\CAP8\C++\EX4_A.CPP e NEXERCÍCAP8ACHNEX4 A. EXE 

22 SOLUÇÃO: FUNÇÃO DEPOIS DA main() 
\EXERC\CAP8\C++\EX4_B.CPP e \EXERC\CAP8\C++\EX4_B.EXE 


RB WIA A SoLução: 
=E \EXERC\CAP8\JAVA\EX4.java e \EXERC\CAP8\JAVA\EX4.class 


EA Crie um programa que receba os valores antigo e atual de um produto. Chame uma sub-rotina que 
determine o percentual de acréscimo entre esses valores. O resultado deverá ser mostrado no programa 
principal. 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE precoantigo, precoatual, acrescimo NUMÉRICO 
LEIA precoantigo 

LEIA precoatual 

acrescimo <- calculo reajuste(precoantigo, precoatual) 
ESCREVA acrescimo 

FIM ALGORITMO. 


SUB-ROTINA calculo reajuste(PA, PN NUMÉRICO ) 
DECLARE result NUMÉRICO 

result 4 (100 * PN — 100 * PA) / PA 
RETORNE result 

FIM SUB ROTINA calculo reajuste 


PASCAL SOLUÇÃO: 
\EXERC\CAP8\PASCAL\EX5.PAS e NEXERCACAP8NPASCALNEXS. EXE 


GEES 
eylen Ra Sorução: 
D \EXERC\CAP8\C++\EX5.CPP e \EXERC\CAP8\C++\EX5.EXE 


RR WIA NA SoLução: 
EA VEXERCICAP8AJAVANEX5. java e \EXERC\CAP8\JAVA\EX5.class 


WA Faça uma sub-rotina que receba como parâmetro um inteiro no intervalo de 1 a 9 e mostre a seguinte 
tabela de multiplicação (no exemplo, n = 9): 


2 4 
3 6 9 

4 8 12 16 

5 10 15 20 25 

6 12 18 24 30 36 

7 14 21 28 35 42 49 

8 16 24 32 40 48 56 64 

9 18 Dm 36 45 54 63 72 81 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE num NUMÉRICO 
REPITA 

LEIA num 
ATÉ (num >= 1) E (num <= 9) 
multiplicacao (num) 
FIM ALGORITMO. 


SUB-ROTINA multiplicacao(n NUMÉRICO) 
DECLARE i, j NUMÉRICO 
PARA i — 1 ATÉ n FAÇA 
INÍCIO 
PARA j — 1 ATÉ i FAÇA 
INÍCIO 
ESCREVA i * j 
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FIM 
FIM 
FIM SUB ROTINA multiplicacao 


PASCAI, SoLUÇÃO: 
GEES \EXERC\CAP8\PASCAL\EX6.PAS e NEXERCÍACAP8NPASCALNEX6 .EXE 


e)AeE RM 12 SoLução: FUNÇÃO ANTES DA main() 
CD \EXERC\CAP8\C++\EX6_A.CPP e \EXERC\CAP8\C++\EX6_A.EXE 


22 SOLUÇÃO: FUNÇÃO DEPOIS DA main () 
\EXERC\CAP8\C++\EX6_B.CPP e \EXERC\CAP8\C++\EX6_B.EXE 


SEGE SoLução: 
D \EXERC\CAP8\JAVA\EX6.java e \EXERC\CAP8\JAVA\EX6.class 


IEA Elabore um programa contendo uma sub-rotina que receba as três notas de um aluno como parâme- 
tros e uma letra. Se a letra for A, a sub-rotina deverá calcular a média aritmética das notas do aluno; se 
for P, deverá calcular a média ponderada, com pesos 5, 3 e 2. A média calculada deverá ser devolvida 
ao programa principal para, então, ser mostrada. 


(AILTSIOJRN ITIMO) Solução: 


ALGORITMO 

DECLARE notal, nota2, nota3, m NUMÉRICO 
letra LITERAL 

LEIA notal 

LEIA nota2 

LEIA nota3 


REPITA 
LEIA letra 
ATÉ (letra = “A”) OU (letra = “P”) 
m < calcula media(notal, nota2, nota3, letra) 
SE letra = “A” 


ENTÃO ESCREVA “A média aritmética “ n im 
SENÃO ESCREVA “A média ponderada “, m 
FIM ALGORITMO. 
SUB-ROTINA calcula media(nl, n2, n3 NUMÉRICO, 1 LITERAL) 
DECLARE media NUMÉRICO 
SER MAM 
ENTÃO media — (nlt+n2+n3)/3 
SENÃO media <-(n1*5+n2*3+n3*2)/(5+3+2) 
RETORNE media 
FIM SUB ROTINA calcula media 


PASCAL SOLUÇÃO: 
D \EXERC\CAP8\PASCAL\EX7.PAS e \EXERC\CAP8\PASCAL\EX7.EXE 


e) ZeRmaD 1º Solução -FUNÇÃO ANTES DA main() 
[a] \EXERC\CAP8\C++\EX7_A.CPP e \EXERC\CAP8\C++\EX7_A.EXE 
22 SOLUÇÃO — FUNÇÃO DEPOIS DA main() 


\EXERC\CAP8\C++\EX7_B.CPP e \EXERC\CAP8\C++\EX7_B.EXE 


SEGE SoLução: 
\EXERC\CAP8\JAVA\EX7.java e \EXERC\CAP8\JAVA\EX7.class 


282 | Fundamentos da programação de computadores 


REA Crie uma sub-rotina que receba como parâmetro a hora de início e a hora de término de um jogo, 
ambas subdivididas em dois valores distintos: horas e minutos. A sub-rotina deverá retornar a duração 
expressa em minutos, considerando que o tempo máximo de duração de um jogo é de 24 horas e que 
ele pode começar em um dia e terminar no outro. 


(ALLISIOJRN INTIMO) Solução: 


ALGORITMO 

DECLARE hora i, min i, hora f, min f, minutos NUMÉRICO 
LEIA hora i, min i 

LEIA hora f, min f 

minutos + calculo(hora i, min i, hora f, min f) 
ESCREVA minutos 

FIM ALGORITMO. 


SUB-ROTINA calculo(h i, m i, h f, m f NUMÉRICO) 
DECLARE tot h, tot m, total NUMÉRICO 
SE m f<mi 
ENTÃO INÍCIO 

mf — mf + 60 
hf-hf-1 
FIM 
SEhf<hi 
ENTÃO INÍCIO 
h f — nhf+a24 
FIM 
totm+e m e o N 
tot h — h £f - h ài 
total < tot h * 60 + tot m 
RETORNE total 
FIM SUB ROTINA calculo 


PASCAL SOLUÇÃO: 
D \EXERC\CAP8\PASCAL\EX8.PAS e \EXERC\CAP8\PASCAL\EX8.EXE 


leE TA l+ SoLução — FUNÇÃO ANTES DA main() 
CEER \EXERC\CAP8\C++\EX8_A.CPP e \EXERC\CAP8\C++\EX8_A.EXE 
22 SOLUÇÃO — FUNÇÃO DEPOIS DA main() 


\EXERC\CAP8\C++\EX8_B.CPP e \EXERC\CAP8\C++\EX8_B.EXE 


RAIA SOLUÇÃO: 
a \EXERC\CAP8\JAVA\EX8.java e \EXERC\CAP8\JAVA\EX8.class 


REA Faça uma sub-rotina que leia cinco valores inteiros, determine e mostre o maior e o menor deles. 


(AILTSIOJRNITIMO) Solução: 


ALGORITMO 
maior menor; 
FIM ALGORITMO. 


SUB-ROTINA maior menor 
DECLARE i, num, maior, menor NUMÉRICO 
PARA i — 1 ATÉ 5 FAÇA 
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INÍCIO 
ESCREVA “Digite o “, i, “º número: ”“ 
LEIA num 
ja dt = dl 
ENTÃO INÍCIO 
maior + num 
menor + num 
FIM 
SENÃO INÍCIO 
SE num > maior 
ENTÃO maior < num 
SE num < menor 
ENTÃO menor < num 


FIM 
FIM 
ESCREVA “O maior número digitado foi: “,maior 
ESCREVA “O menor número digitado foi: “,menor 


FIM SUB ROTINA maior menor 


PASCAL SOLUÇÃO: 
D \EXERC\CAP8\PASCAL\EX9.PAS e \EXERC\CAP8\PASCAL\EX9.EXE 


ePleE TMA 12 SoLução — FUNÇÃO ANTES DA main() 
EEE \EXERC\CAP8\C++\EX9_A.CPP e \EXERC\CAP8\C++\EX9_A.EXE 


22 SOLUÇÃO — FUNÇÃO DEPOIS DA main() 


\EXERC\CAP8\C++\EX9_B.CPP e \EXERC\CAP8\C++\EX9_B.EXE 


SEGE SoLução: 
D \EXERC\CAP8\JAVA\EX9.java e \EXERC\CAP8\JAVA\EX9.class 


HA Crie uma sub-rotina que receba como parâmetro um valor inteiro e positivo N e retorne o valor de S, 
obtido pelo seguinte cálculo: 


S = 1 + 1/1! + 1/2! + 1/3! +... + 1/N! 
(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE num, s NUMÉRICO 
LEIA num 

s + sequencia (num) 
ESCREVA s 

FIM ALGORITMO. 


SUB-ROTINA sequencia(n NUMÉRICO) 
DECLARE a, b, f, seq NUMÉRICO 


seq <— 1 
PARA a — 1 ATÉ n FAÇA 
INÍCIO 
poço A 
PARA b — 1 ATÉ a FAÇA 
INÍCIO 


B G= Uno a o 
FIM 
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seg = seq+ 1 / £ 
FIM 

RETORNE seq 

FIM SUB ROTINA sequencia 


PASCAL [SioRioito 
\EXERC\CAP8\PASCAL\EX10.PAS e VEXERCICAP8NPASCALNEX10.EXE 


Lee = 1º SoLução — FUNÇÃO ANTES DA main() 
c \EXERC\CAP8\C++\EX10_A.CPP e \EXERC\CAP8\C++\EX10_A.EXE 
22 SOLUÇÃO — FUNÇÃO DEPOIS DA main() 


\EXERC\CAP8\C++\EX10_B.CPP e \EXERC\CAP8\C++\EX10_B.EXE 


RANMA SoLução: 
\EXERC\CAP8\JAVA\EX10.java e \EXERC\CAP8\JAVA\EX10.class 


EEB Foi realizada uma pesquisa sobre algumas características físicas de cinco habitantes de uma região. 
Foram coletados os seguintes dados de cada habitante: sexo, cor dos olhos (A — azuis; ou C — casta- 
nhos), cor dos cabelos (L — louros; P — pretos; ou C — castanhos) e idade. Faça um programa que 
apresente as sub-rotinas a seguir: 


Que leia esses dados, armazenando-os em vetores. 


Que determine e devolva ao programa principal a média de idade das pessoas com olhos castanhos 
e cabelos pretos. 


Que determine e devolva ao programa principal a maior idade entre os habitantes. 


Que determine e devolva ao programa principal a quantidade de indivíduos do sexo feminino com 
idade entre 18 e 35 anos (inclusive) e que tenham olhos azuis e cabelos louros. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE sexo[5], olhos[5], cabelos[5] LITERAL 
idade[5], x, i, q, m NUMÉRICO 

leitura (sexo, olhos, cabelos, idade) 

m < media idade(olhos, cabelos, idade) 

ESCREVA m 

i « maior idade(sexo, olhos, cabelos, idade) 

ESCREVA i 

q — qt individuos(sexo, olhos, cabelos, idade) 

ESCREVA q 

FIM ALGORITMO. 


SUB-ROTINA leitura(sexo[5], olhos[5], cabelos[5] LITERAL, 
idade[5] NUMÉRICO) 
DECLARE x NUMÉRICO 
PARA x — 1 ATÉ 5 FAÇA 
INÍCIO 
REPITA 
LEIA sexo[x] 
ATÉ (sexo[x] = “F”) OU (sexo[x] = “M”) 
REPITA 
LEIA olhos[x] 
ATÉ (olhos[x] = “C”) OU (olhos[x] = “A”) 
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REPITA 
LEIA cabelos[x] 
ATÉ (cabelos[x] = “C” OU cabelos[x] = “L” OU cabelos[x] = “P”) 
LEIA idade[x] 
FIM 
FIM SUB ROTINA leitura 


SUB-ROTINA media idade (olhos[5], cabelos[5] LITERAL, 
idade[5] NUMÉRICO) 
DECLARE i, cont, soma, media NUMÉRICO 
soma <— 0 
cont <— 0 
PARA i < 1 ATÉ 5 FAÇA 
INÍCIO 
SE (olhos[i] = “C”) E (cabelos[i] = “P”) 
ENTÃO INÍCIO 
soma + soma + idade[i] 
cont — cont + 1 
FIM 
FIM 
SE cont = 0 
ENTÃO media — 0 
SENÃO media <— soma / cont 
RETORNE media 
FIM SUB-ROTINA media idade 


SUB-ROTINA maior idade (idade[5] NUMÉRICO) 
DECLARE i, maior NUMÉRICO 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
SE i=1 
ENTÃO maior <  idade[i] 
SENÃO INÍCIO 
SE (idade[i] > maior) 
ENTÃO maior < idade[i] 
FIM 
FIM 
RETORNE maior 
FIM SUB ROTINA maior idade 
SUB-ROTINA gt individuos(sexo[5],olhos[5],cabelos[5] LITERAL, 
idade[5] NUMÉRICO) 
DECLARE i, qtd NUMÉRICO 


gqtd — O 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
SE sexo[i] = “F” E idade[i] >= 18 E idade[i] <= 35 E 
olhos[i] = “A” E cabelos[i] = “L” 
ENTÃO qtd — qtd + 1 
FIM 


RETORNE qtd 
FIM SUB ROTINA qt individuos 


TARSO NH SOLUÇÃO: 
mi! \EXERC\CAP8\PASCAL\EX11.PAS e \EXERC\CAP8\PASCAL\EX11.EXE 


c/c++ ERROS 
E \EXERC\CAP8\C++\EX11.CPP e NEXERCACAP8AC++NEX11.EXE 
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SENA SoLução: 
GERE \EXERC\CAP8\JAVA\EX11.java e \EXERC\CAP8\JAVA\EX11.class 


EFA Elabore uma sub-rotina que retorne um vetor com os três primeiros números perfeitos. Sabe-se que um 
número é perfeito quando é igual à soma de seus divisores (exceto ele mesmo). Exemplo: os divisores 
de 6 são 1,2e3,e1+2+3=6,logo 6 é perfeito. 


(ALLTSIOJEN ITIMO) Solução: 


ALGORITMO 

DECLARE vet[3], i NUMÉRICO 

perfeitos (vet) 

PARA i <— 1 ATÉ 3 FAÇA 

INÍCIO 
ESCREVA vet[i] 
FIM 

FIM ALGORITMO. 

SUB-ROTINA perfeitos(v[3] NUMÉRICO) 
DECLARE a, r, num, soma, cont NUMÉRICO 
conto 
num — 1 
ENQUANTO (cont < 3) FAÇA 

INÍCIO 
soma <— 0 
PARA a — 1 ATÉ num-l FAÇA 


INÍCIO 

r + RESTO(num / a) 

SE r = 0 

ENTÃO soma +— soma + a 
FIM 


SE soma = num 
ENTÃO INÍCIO 
v[cont + 1] — num 
Cont conta 
FIM 
num <— num + 1 
FIM 


FIM SUB ROTINA perfeitos 


PASCAL SOLUÇÃO: 
Ee VEXERCACAP8NPASCALVEX12.PAS e NEXERCACAP8NPASCALNEX12.EXE 


C/C++ Sorução: 
D \EXERC\CAP8\C++\EX12.CPP e \EXERC\CAP8\C++\EX12.EXE 


SEAIA SoLução: 
GEES \EXERC\CAP8\JAVA\EX12.java e \EXERC\CAP8\JAVA\EX12.class 


EER Faça uma sub-rotina que receba um vetor A de dez elementos inteiros como parâmetro. Ao final dessa 


função, deverá ter sido gerado um vetor B contendo o fatorial de cada elemento de A. O vetor B deverá 
ser mostrado no programa principal. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE x, vet1[10], vet2[10] NUMÉRICO 
PARA x +— 1 ATÉ 10 FAÇA 
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INÍCIO 
LEIA vetl[x] 
FIM 
fatoriais(vetl, vet2) 
PARA x < 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA vet2[x] 
FIM 
FIM ALGORITMO. 


SUB-ROTINA fatoriais(a[10], b[10] NUMÉRICO) 
DECLARE i, j , f NUMÉRICO 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
SE (a[i] = 0) OU (a[i] = 1) 
ENTÃO b[i] — 1 
SENÃO INÍCIO 
sjaj = i 
PARA j — 1 ATÉ a[i] FAÇA 
INÍCIO 
b[il — b[i] * 35 
FIM 
FIM 
FIM 
FIM SUB ROTINA fatoriais 


TARSO NH SOLUÇÃO: 
Rms VEXERCACAP8NPASCALVEX13.PAS e NEXERCICAPSAPASCALNEX13.EXE 


C/c++ ERROS 
D \EXERC\CAP8\C++\EX13.CPP e \EXERC\CAP8\C++\EX13.EXE 


VENA SOLUÇÃO: 
D \EXERC\CAP8\JAVA\EX13.java e \EXERC\CAP8\JAVA\EX13.class 


ELJ Crie uma sub-rotina que receba como parâmetro dois vetores de dez elementos inteiros positivos e 
mostre o vetor união dos dois primeiros. 


(AJLIGIOJRN ITIM(O) SoLução: 


ALGORITMO 
DECLARE x, vet1[10], vet2[10], vet3[20], cont NUMÉRICO 
PARA x +— 1 ATÉ 10 FAÇA 
INÍCIO 
REPITA 
LEIA vetl[x] 
ATÉ vetl[x] >= 0 
FIM 
PARA x < 1 ATÉ 10 FAÇA 
INÍCIO 
REPITA 
LEIA vet2[x] 
ATÉ vet2[x] >= 0 
FIM 
cont + uniao(vetl,vet2,vet3) 
me q dl 
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ENQUANTO x < cont FAÇA 
INÍCIO 
ESCREVA vet3[x] 
FIM 
FIM ALGORITMO. 


SUB-ROTINA uniao(a[10], b[10], u[20] NUMÉRICO) 
DECLARE i, j, k, cont NUMÉRICO 
k=1 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
(je <— dl 
ENQUANTO cont < k E a[i] É u[lcont] FAÇA 
INÍCIO 
cont = conta 
FIM 
SE cont = k 
ENTÃO INÍCIO 
uk] <— a[i]l 
k — k+1 
FIM 
FIM 
PARA i — 1 ATÉ 10 FAÇA INÍCIO 
cont <— 1 
ENQUANTO cont < k E b[i]l É u[cont] FAÇA 
INÍCIO 
cont < cont + 1 
FIM 
SE cont = k 
ENTÃO INÍCIO 
u[k] — bi] 


ke k+1 
FIM 

FIM 

RETORNE k 


FIM SUB ROTINA uniao 


SOLUÇÃO: 


VEXERCACAP8APASCALVEX14.PAS e \EXERC\CAP8\PASCAL\EX14.EXE 
SOLUÇÃO: 


PASCAL 
[SE] 
C/C++ 
Esso \EXERC\CAP8\C++\EX14.CPP e NEXERCACAP8AC++NEX14. EXE 
JAVA A SoLuçÃo: 

(So e 


\EXERC\CAP8\JAVA\EX14.java e \EXERC\CAP8\JAVA\EX14.class 


EER Faça uma sub-rotina que receba como parâmetro um vetor A com cinco números reais e retorne esses 
números ordenados de forma crescente. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE x, vet[5] NUMÉRICO 
PARA x <— 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA vet [x] 
FIM 
ordena(vet) 
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PARA x — 1 ATÉ 5 FAÇA 
INÍCIO 
ESCREVA vet [x] 
FIM 
FIM ALGORITMO. 


SUB-ROTINA ordena (v[5] NUMÉRICO) 
DECLARE i, j, aux NUMÉRICO 
PARA i < 1 ATÉ 5 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
SE (v[j] > ao 
ENTÃO INÍCIO 
aux <— v[5] 
v[j] — vlj+1] 
v[j+1] — aux 
FIM 
FIM 
FIM 


FIM SUB ROTINA ordena 


PASCAL SoLUÇÃO: 

ee) \EXERC\CAP8\PASCAL\EX15.PAS e VEXERCNCAP8NPASCALNEX15.EXE 
C/C++ 

Z 


SOLUÇÃO: 
\EXERC\CAP8\C++\EX15.CPP e \EXERC\CAP8\C++\EX15.EXE 


RAIA SOLUÇÃO: 
D \EXERC\CAP8\JAVA\EX15.java e \EXERC\CAP8\JAVA\EX15.class 


HA Crie uma sub-rotina que receba dois vetores A e B de dez elementos inteiros como parâmetro. A sub- 
-rotina deverá determinar e mostrar um vetor C que contenha os elementos de A e B em ordem decres- 
cente. O vetor C deverá ser mostrado no programa principal. 


EELER ITIMO) Solução: 


ALGORITMO 
DECLARE x, vet1[10], vet2[10], vet3[20] NUMÉRICO 
PARA x +— 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vet1l[x] 
FIM 
PARA x +— 1 ATÉ 10 FAÇA 
INÍCIO 
LEIA vet2[x] 
FIM 
ordena todos(vetl,vet2,vet3) 
PARA x < 1 ATÉ 20 FAÇA 
INÍCIO 
ESCREVA vet3[x] 
FIM 
FIM ALGORITMO. 
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SUB-ROTINA ordena todos(a[10], b[10], c[20] NUMÉRICO) 
DECLARE i, j, k, cont NUMÉRICO 
le = dl 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 
cont — 1 
ENQUANTO cont < k E a[i] < c[cont] FAÇA 
INÍCIO 
cont < cont + 1 
FIM 
SE cont = k 
ENTÃO INÍCIO 
c[k] — ali] 
Je se dk sp dl 
FIM 
SENÃO INÍCIO 
PARA j <— k-1 ATÉ cont PASSO -1 FAÇA 


INÍCIO 
Giat = elis) 
FIM 
c[cont] + a[i] 
la = le ap dl 
FIM 
FIM 
PARA i < 1 ATÉ 10 FAÇA 
INÍCIO 


come > 4 
ENQUANTO cont < k E b[i] < c[cont] FAÇA 
INÍCIO 
cont < cont + 1 
FIM 
SE cont = k 
ENTÃO INÍCIO 
c[k] <— b[i] 
k = de sp dl 
FIM 
SENÃO INÍCIO 
PARA j — K-1 ATÉ cont PASSO -1 FAÇA 


INÍCIO 

Gasal = ea] 
FIM 

c[cont] — b[i] 
ke k+1 

FIM 


FIM 
FIM SUB ROTINA ordena todos 
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PASCAI, SoLUÇÃO: 
D \EXERC\CAP8\PASCAL\EX16.PAS e \EXERC\CAP8\PASCAL\EX16.EXE 


C/C++ SoLuçÃo: 
\EXERC\CAP8\C++\EX16.CPP e \EXERC\CAP8\C++\EX16.EXE 


D 
RB LWIAN SoLução: 
in \EXERC\CAP8\JAVA\EX16.java e \EXERC\CAP8\JAVA\EX16.class 


EFA Faça uma sub-rotina que receba como parâmetro uma matriz A(5,5) e retorne a soma de seus elementos. 


ELPRIM O Solução: 


ALGORITMO 
DECLARE x, y, S, matriz[5,5] NUMÉRICO 
PARA x — 1 ATÉ 5 FAÇA 
INÍCIO 
PARA y <— 1 ATÉ 5 FAÇA 
INÍCIO 
LEIA matriz[x,y] 
FIM 
FIM 
s + soma matriz(matriz) 
ESCREVA s 
FIM ALGORITMO. 
SUB-ROTINA soma matriz(m[5,5] NUMÉRICO) 
DECLARE i, j, soma NUMÉRICO 
soma — 0 
PARA i — 1 ATÉ 5 FAÇA 


INÍCIO 
PARA j — 1 ATÉ 5 FAÇA 
INÍCIO 
soma +— soma + m[i, j] 
FIM 
FIM 


RETORNE soma 
FIM SUB-ROTINA soma_matriz 


PASCAL SOLUÇÃO: 
D \EXERC\CAP8\PASCAL\EX17.PAS e \EXERC\CAP8\PASCAL\EX17.EXE 


c/c++ Solução: 
CE \EXERC\CAP8\C++\EX17.CPP e \EXERC\CAP8\C++\EX17.EXE 


RANMA SoLução: 
finado \EXERC\CAP8\JAVA\EX17.java e NEXERCICAP8IJAVANEX17.class 


EEJ Crie uma sub-rotina que receba como parâmetro uma matriz A(6,6) e retorne o menor elemento de 
sua diagonal secundária. 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 
DECLARE x, y, menor, matriz[6,6] NUMÉRICO 
PARA x — 1 ATÉ 6 FAÇA 

INÍCIO 
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PARA y — 1 ATÉ 6 FAÇA 
INÍCIO 
LEIA matriz[x,y] 
FIM 
FIM 
menor + menor elemento(matriz) 
ESCREVA menor 
FIM ALGORITMO. 


SUB-ROTINA menor elemento(m[6,6] NUMÉRICO) 
DECLARE i, j, me NUMÉRICO 
me — m[1,6] 

J= 5 
PARA i — 2 ATÉ 6 FAÇA 
INÍCIO 
SE m[i,j] < me 
ENTÃO me — m[i,j] 
ab Se af dE 
FIM 
RETORNE me 
FIM SUB ROTINA menor elemento 


PASCAL, [SOR o tos 
E \EXERC\CAP8\PASCAL\EX18.PAS e NEXERCICAP8NPASCALNEX18.EXE 


ylen Ra Sorução: 
GERE \EXERC\CAP8\C++\EX18.CPP e \EXERC\CAP8\C++\EX18.EXE 


E-G- SoLução: 
CD \EXERC\CAP8\JAVA\EX18.java e \EXERC\CAP8\JAVA\EX18.class 


ELJ Elabore uma sub-rotina que receba como parâmetro uma matriz A(6,6) e multiplique cada linha pelo 
elemento da diagonal principal da linha. A sub-rotina deverá retornar a matriz alterada para ser mos- 
trada no programa principal. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE x, y, matriz[6,6] NUMÉRICO 
PARA x — 1 ATÉ 6 FAÇA 


INÍCIO 
PARA y — 1 ATÉ 6 FAÇA 
INÍCIO 
LEIA matriz[x,y] 
FIM 
FIM 


multiplica matriz(matriz) 
PARA x — 1 ATÉ 6 FAÇA 
INÍCIO 
PARA y <— 1 ATÉ 6 FAÇA 
INÍCIO 
ESCREVA matriz[x,y] 
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FIM 
FIM 
FIM ALGORITMO. 


SUB-ROTINA multiplica matriz(m[6,6] NUMÉRICO) 
DECLARE i, j, v NUMÉRICO 
PARA i < 1 ATÉ 6 FAÇA 
INÍCIO 
S ai] 
PARA j — 1 ATÉ 6 FAÇA 
INÍCIO 
m[iJ[j] = m[illj] * v 
FIM 
FIM 
FIM SUB ROTINA multiplica matriz 


PASCAL SOLUÇÃO: 
= \EXERC\CAP8\PASCAL\EX19.PAS e \EXERC\CAP8\PASCAL\EX19.EXE 


c/c++ Solução: 

\EXERC\CAP8\C++\EX19.CPP e \EXERC\CAP8\C++\EX19.EXE 
BAIANO SOLUÇÃO: 

\EXERC\CAP8\JAVA\EX19.java e \EXERC\CAP8\JAVA\EX19.class 


dos elementos abaixo da diagonal principal. 


(AJLIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE x, y, matriz[12,12], m NUMÉRICO 
PARA x — 1 ATÉ 12 FAÇA 
INÍCIO 
PARA y — 1 ATÉ 12 FAÇA 
INÍCIO 
LEIA matriz[x,y] 
FIM 
FIM 
m < media aritmetica(matriz) 
ESCREVA m 
FIM ALGORITMO. 


SUB-ROTINA media aritmetica(m[12,12] NUMÉRICO) 

DECLARE i, j, cont, soma, media NUMÉRICO 

soma — 0 

cont — O 

PARA i — 2 ATÉ 12 FAÇA 

INÍCIO 
PARA j — 12 ATÉ (14 - i ) PASSO -1 FAÇA 
INÍCIO 

soma — soma + m[i,5] 
cont < cont + 1 


EIA Crie uma sub-rotina que receba como parâmetro uma matriz A(12,12) e retorne a média aritmética 
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FIM 
FIM 
media —  soma/cont 
RETORNE media 
FIM SUB ROTINA media aritmetica 


TARSO NH SOLUÇÃO: 

Cz \EXERC\CAP8\PASCAL\EX20.PAS e \EXERC\CAP8\PASCAL\EX20.EXE 
VETA Solução: 

E \EXERC\CAP8\C++\EX20.CPP e NEXERCACAP8AC++NVEX20. EXE 


RANMA SoLução: 
E VEXERCICAP8AJAVANEX20. java e \EXERC\CAP8\JAVA\EX20.class 


PIE Escreva um algoritmo que leia um número não determinado de pares de valores x,y (x obrigatoria- 
mente deve ser menor que y), todos inteiros e positivos, um par de cada vez. Para cada par, chame uma 
sub-rotina que determine a soma dos números primos entre x e y (inclusive). O algoritmo deverá mos- 
trar os valores de x e de y, seguidos pelo somatório calculado. A leitura dos pares terminará quando os 
valores digitados para x e y forem iguais. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE x, y, soma NUMÉRICO 
LEIA x 
LEIA y 
ENQUANTO x +Æ y FAÇA 
INÍCIO 
soma + primos(x, y) 
ESCREVA soma 
LEIA x 
LEIA y 
FIM 
FIM ALGORITMO. 


SUB-ROTINA primos(x, y NUMÉRICO) 
DECLARE i, j, r, cont, somatorio NUMÉRICO 
somatorio + 0 
PARA i <— x ATÉ y FAÇA 
INÍCIO 
cont < 0 
PARA j — 1 ATÉ i FAÇA 


INÍCIO 
r — RESTO(i / j) 
SE r = 0 


ENTÃO cont <— cont + 1 
FIM 
SE cont <= 2 
somatorio <-  somatorio + i 
FIM 
RETORNE somatorio 
FIM SUB ROTINA primos 
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PASCAI, SoLUÇÃO: 
Ena VEXERCACAP8NPASCALVEX21.PAS e NEXERCICAPSAPASCALNEX21.EXE 


eyler Ra SoLução: 
\EXERC\CAP8\C++\EX21.CPP e \EXERC\CAP8\C++\EX21.EXE 


E 
nE-GA A SoLução: 
Ras \EXERC\CAP8\JAVA\EX21.java e \EXERC\CAP8\JAVA\EX21.class 


EYA Crie um programa que carregue um vetor com oito números inteiros, calcule e mostre dois vetores 
resultantes. O primeiro vetor resultante deverá conter os números positivos e o segundo, os números 
negativos. Cada vetor resultante terá no máximo oito posições, e nem todas serão obrigatoriamente 
utilizadas. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE vet1[8], vet2[8], vet3[8], i, contl, cont2 NUMÉRICO 
PARA i — 1 ATÉ 8 FAÇA 
INÍCIO 
LEIA vet1[i] 
FIM 
contl < pares(vetl, vet2) 
SE contl = 1 
ENTÃO ESCREVA “NENHUM PAR FOI DIGITADO” 
SENÃO 
PARA i < 1 ATÉ contl - 1 FAÇA 
INÍCIO 
ESCREVA vet2[i] 
FIM 
cont2 +— impares(vetl, vet3) 
SE cont2 = 1 
ENTÃO ESCREVA “NENHUM ÍMPAR FOI DIGITADO” 
SENÃO 
PARA i < 1 ATÉ cont2 - 1 FAÇA 
INÍCIO 
ESCREVA vet3[i] 
FIM 
FIM ALGORITMO. 


SUB-ROTINA pares(vl[8], v2[8] NUMÉRICO) 
DECLARE i, r, cont NUMÉRICO 

contk I 

PARA i — 1 ATÉ 8 FAÇA 


INÍCIO 
r + RESTO(vl[i] / 2) 
SE r = 0 


ENTÃO INÍCIO 
v2[cont] — vl[i] 
cont + cont + 1 
FIM 
FIM 
RETORNE cont 
FIM SUB ROTINA pares 


296 | Fundamentos da programação de computadores 


SUB-ROTINA impares(vl[8], v2[8] NUMÉRICO) 
DECLARE i, r, cont NUMÉRICO 
cont < 
PARA i <— 1 ATÉ 8 FAÇA 


INÍCIO 
r + RESTO(vl[i] / 2) 
SE 


ENTÃO INÍCIO 
v2[cont] <— vl[i] 
cont < cont + 1 
FIM 
FIM 
RETORNE cont 
FIM SUB ROTINA impares 


PASCAL, [Sono to 
Fan VEXERCACAP8NPASCALVEX22.PAS e VEXERCACAP8NPASCALNEX22.EXE 


C/C++ SoLução: 
ES \EXERC\CAP8\C++\EX22.CPP e \EXERC\CAP8\C++\EX22.EXE 


RNA SoLução: 
EEE \EXERC\CAP8\JAVA\EX22.java e NEXERCICAP8AJAVANEX22.class 


PER Crie um programa que carregue uma matriz 3X4 com números reais. Utilize uma função para copiar 
todos os valores da matriz para um vetor de 12 posições. Esse vetor deverá ser mostrado no programa 
principal. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE mat [3,4], vet[12], i, j NUMÉRICO 
PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
LEIA mat[1,5] 
FIM 
FIM 
gera vetor(mat, vet) 
PARA i — 1 ATÉ 12 FAÇA 
INÍCIO 
ESCREVA vet[i] 
FIM 
FIM ALGORITMO. 


SUB ROTINA gera vetor(m[3,4], v[12] NUMÉRICO) 
DECLARE i, j, k NUMÉRICO 
je = à 
PARA i < 1 ATÉ 3 FAÇA 
INÍCIO 
PARA j — 1 ATÉ 4 FAÇA 
INÍCIO 
v[k] <— m[i,)] k <— k+1 
FIM 
FIM 
FIM SUB ROTINA gera vetor 
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PASCAI, SoLUÇÃO: 
D \EXERC\CAP8\PASCAL\EX23.PAS e \EXERC\CAP8\PASCAL\EX23.EXE 


C/C++ SoLuçÃo: 
\EXERC\CAP8\C++\EX23.CPP e \EXERC\CAP8\C++\EX23.EXE 


D 
RB WIA A SoLução: 
te VEXERCICAP8AJAVANEX23. java e \EXERC\CAP8\JAVA\EX23.class 


EZY Faça um programa contendo uma sub-rotina que receba dois valores numéricos e um símbolo. Esse 
símbolo representará a operação que se deseja efetuar com os números. Se o símbolo for +, deverá ser re- 
alizada uma adição, e, se for *, deverá ser efetuada uma multiplicação. O resultado deverá ser mostrado 
no programa principal. 


(AILTSIOJRILITIMO) Sorução: 


ALGORITMO 
DECLARE numl, num2, res NUMÉRICO 
op LITERAL 
LEIA numl 
LEIA num? 
REPITA 
LEIA op 
ATÉ op = '+' OU op = '*" 
res + calculo (numl, num2, op) 
ESCREVA res 
FIM ALGORITMO. 


SUB-ROTINA calculo(nl, n2 NUMÉRICO, simbolo LITERAL) 
DECLARE result NUMÉRICO 
SE simbolo = '+' 
ENTÃO result — nl + n2 
SENAO result — nl * n2 
RETORNE result 
FIM SUB ROTINA calculo 


PASCAI, SoLUÇÃO: 
VEXERCACAP8NPASCALVEX24.PAS e VEXERCACAP8NPASCALNEX24.EXE 


C/c++ ENIO 
\EXERC\CAP8\C++\EX24.CPP e \EXERC\CAP8\C++\EX24.EXE 


SEGS SoLução: 


m \EXERC\CAP8\JAVA\EX24.java e \EXERC\CAP8\JAVA\EX24.class 


FER Crie uma sub-rotina que receba como parâmetro um vetor A de 25 números inteiros e substitua todos os 
valores negativos de À por zero. O vetor resultante deverá ser mostrado no programa principal. 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 

DECLARE vetor[25], i NUMÉRICO 

PARA i < 1 ATÉ 25 FAÇA 
INÍCIO 
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LEIA vetor[i] 

FIM 
substituicao(vetor) 
PARA i <— 1 ATÉ 25 FAÇA 

INÍCIO 

ESCREVA vetor[i] 

FIM 

FIM ALGORITMO. 


SUB-ROTINA substituicao(vet [25] NUMÉRICO) 
DECLARE z NUMÉRICO 
PARA z — 1 ATÉ 25 FAÇA 
INÍCIO 
SE vet[z] < 0 
ENTÃO vet[z] — 0 
FIM 
FIM SUB ROTINA substituicao 


PASCAL SOLUÇÃO: 

cE \EXERC\CAP8\PASCAL\EX25.PAS e \EXERC\CAP8\PASCAL\EX25.EXE 
ylona SoLuçÃO: 

GEREs \EXERC\CAP8\C++\EX25.CPP e \EXERC\CAP8\C++\EX25. EXE 


E-G- SoLução: 
Ed \EXERC\CAP8\JAVA\EX25.java e NEXERCICAP8AJAVANEX25.class 


EXERCÍCIOS PROPOSTOS 


BEER Faça uma sub-rotina que receba um número inteiro e positivo N como parâmetro e retorne a soma dos núme- 
ros inteiros existentes entre o número 1 e N (inclusive). 


IFA Crie uma sub-rotina que receba três números inteiros como parâmetros, representando horas, minutos e se- 
gundos, e os converta em segundos. Exemplo: 2h, 40min e 10s correspondem a 9.610 segundos. 


IEJ Flabore uma sub-rotina que receba dois números como parâmetros e retorne 0, se o primeiro número for 
divisível pelo segundo número. Caso contrário, deverá retornar o próximo divisor. 


I Faça uma sub-rotina que receba como parâmetro o raio de uma esfera, calcule e mostre no programa principal 
o seu volume: v = 4/3 * Rº. 


EA Faça uma sub-rotina que receba um valor inteiro e verifique se ele é positivo ou negativo. 


WA Crie uma sub-rotina que receba como parâmetro a altura (alt) e o sexo de uma pessoa e retorne seu peso ideal. 
Para homens, deverá calcular o peso ideal usando a fórmula: peso ideal = 72.7 *alt - 58; para mulheres: peso 
ideal = 62.1 *alt - 44.7. 


IEA Flabore uma sub-rotina que leia um número não determinado de valores positivos e retorne a média aritmé- 
tica desses valores. Terminar a entrada de dados com o valor zero. 


REA Faça uma sub-rotina que receba um valor inteiro e positivo, calcule e mostre seu fatorial. 


BEER Crie uma sub-rotina que receba como parâmetro um valor inteiro e positivo e retorne a soma dos divisores 
desse valor. 


ETA Elabore uma sub-rotina que receba como parâmetro um valor N (inteiro e maior ou iguala 1) e determi- 
ne o valor da sequência S, descrita a seguir: 


Se dos 1/2 4 1/8400 
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QQQ Observação 


A quantidade de parcelas que compõe S é igual a N. 


EIR Faça uma sub-rotina que receba como parâmetro um valor inteiro e positivo N, indicando a quantidade 
de parcelas de uma soma S, calculada pela fórmula: 


Sa A/a a B/S ss 1O 4% V/I ar 2GS m sos (mM? a L/U S) 


EFA Crie uma sub-rotina que receba como parâmetro dois valores X e Z, calcule e retorne X” sem utilizar 
funções ou operadores de potência prontos. 


EFJ Foi realizada uma pesquisa entre 15 habitantes de uma região. Os dados coletados de cada habitante 
foram: idade, sexo, salário e número de filhos. 
Faça uma sub-rotina que leia esses dados armazenando-os em vetores. Depois, crie sub-rotinas que 
recebam esses vetores como parâmetro e retornem a média de salário entre os habitantes, a menor e a 
maior idade do grupo e a quantidade de mulheres com três filhos que recebem até R$ 500,00 (utilize 
uma sub-rotina para cada cálculo). 


ELA Faça uma sub-rotina que receba um vetor X de 30 elementos inteiros como parâmetro e retorne dois 
vetores A e B. O vetor A deve conter os elementos de X que sejam maiores que zero e o vetor B, os ele- 
mentos menores ou iguais a zero. 


HA Elabore uma sub-rotina que receba um vetor X de 15 números inteiros como parâmetro e retorne a 
quantidade de valores pares em X. 


HA Faça uma sub-rotina que receba um vetor X de 20 de números reais como parâmetro e retorne a soma 
dos elementos de X. 


EFA Elabore uma sub-rotina que calcule o máximo divisor comum (MDC) de dois números recebidos como 
parâmetros. 


EEJ Crie uma sub-rotina que gere e mostre os três primeiros números primos acima de 100. 


ELJ Faça uma sub-rotina que receba como parâmetro dois vetores de dez números inteiros, determine e mos- 
tre o vetor intersecção entre eles. 


EYA A prefeitura de uma cidade fez uma pesquisa entre seus habitantes, coletando dados sobre o salário e o 
número de filhos. Faça uma sub-rotina que leia esses dados para um número não determinado de pessoas 
e retorne a média de salário da população, a média do número de filhos, o maior salário e o percentual 
de pessoas com salário inferior a R$ 380,00. 


PIE Faça uma sub-rotina que receba uma matriz 10X10 e determine o maior elemento acima da diagonal 
principal. Esse valor deverá ser mostrado no programa principal. 
EYA Criar um programa que: 
utilize uma sub-rotina para receber os elementos de uma matriz 10X5 de números reais; 
utilize uma sub-rotina para calcular a soma de todos os elementos localizados abaixo da sexta linha 


dessa matriz; 
Os resultados deverão ser mostrados no programa principal. 


PER Crie um programa que receba três valores (obrigatoriamente maiores que zero), representando as medi- 
das dos três lados de um triângulo. 
Elabore sub-rotinas para: 


determinar se esses lados formam um triângulo (sabe-se que, para ser triângulo, a medida de um 
lado qualquer deve ser inferior ou igual à soma das medidas dos outros dois). 
determinar e mostrar o tipo de triângulo (equilátero, isósceles ou escaleno), caso as medidas for- 
mem um triângulo. 

Todas as mensagens deverão ser mostradas no programa principal. 
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EZY Faça um programa que receba a temperatura média de cada mês do ano e armazene-as em um vetor. O 
programa deverá calcular e mostrar a maior e a menor temperatura do ano, junto com o mês em que elas 
ocorreram (o mês deverá ser mostrado por extenso: 1 = janeiro; 2 = fevereiro; ...). 


Não se preocupe com empates. Cada cálculo deve ser realizado e mostrado em uma sub-rotina. 


PER Crie um programa que receba o número dos 10 alunos de uma sala, armazenando-os em um vetor, junto 
com as notas obtidas ao longo do semestre (foram realizadas quatro avaliações). Elabore sub-rotinas para: 


= determinar e mostrar a média aritmética de todos os alunos; 


= indicar os números dos alunos que deverão fazer recuperação, ou seja, aqueles com média inferior a 6. 


Todas as mensagens deverão ser mostradas no programa principal. 


CAPÍTULO 


Manipulando 
cadeias de 


caracteres 


9.1 Manipulando cadeias de caracteres em PASCAL 


As cadeias de caracteres em PASCAL são representadas pelo tipo de dado conhecido como STRING. 
Uma STRING em PASCAL é uma sequência de símbolos delimitada por apóstrofos. Quando um apóstrofo 
fizer parte da STRING, deverá aparecer duplicado. 

Quando uma variável é declarada como do tipo STRING, é possível definir seu tamanho máximo. Quan- 
do a definição do tamanho for omitida, a STRING assumirá o tamanho máximo permitido de 255 caracteres. 


Exemplos de variáveis do tipo STRING: 


VAR NOME: STRING[20]; A variável NOME poderá armazenar até 20 caracteres. 

VAR SEXO: STRING[3]; A variável sexo poderá armazenar até três caracteres. 

VAR CURSO: STRING; À variável curso não tem tamanho predefinido, logo, poderá armazenar 
até 255 caracteres. 

NOME := 'Maria'; O conteúdo da variável nome é Maria. 

CURSO := 'D''ÁGUA'; O conteúdo da variável curso é p'Ácua. Observe a duplicação do apóstrofo. 


QOQ Observação | 


Na linguagem PASCAL a primeira posição de uma cadeia de caracteres é a posição um. 


9.1.1 Inicializando cadeias de caracteres 


As variáveis que armazenam as cadeias de caracteres podem ser inicializadas automaticamente pelo 
programa ou podem receber um valor por meio do teclado. A seguir, exemplificamos alguns casos. 


a) Inicialização por meio da atribuição 


VAR cadeia: STRING; 
cadeia := 'Programa”'; 


A variável cadeia recebe um valor constante, a palavra Programa. 
b) Inicialização por meio do teclado 

VAR cadeia: STRING; 

READIN (cadeia); 


O comando READLN armazena dentro da variável cadeia todos os símbolos digitados até a ocorrência 
do ENTER. 


9.1.2 Copiando cadeias de caracteres 


cadeia? := COPY (cadeial, posição, número); 
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A função copy copia da cadeial, a partir da posição dada, o número de caracteres estipulados. Os 
caracteres copiados serão armazenados na cadeia2. 


cadeial:= cadeia2; 


O conteúdo da variável cadeia2, que é uma variável do tipo STRING, será copiado para a variável ca- 
deial, que também é do tipo STRING. 


Outros exemplos da função copy podem ser encontrados em: 
YEXEMPLOSICAPANPASCALEXEMPI.PAS e EXEMPLOSICAPNPASCALEXEMP2.PAS. 


9.1.3 Concatenando cadeias de caracteres 
cadeia3 := CONCAT(cadeial,cadeia2); ou cadeia3 := cadeial+cadeia2; 


A função coNcaT concatena a cadeia de caracteres cadeial e a cadeia de caracteres cadeia2, ou seja, 
junta os conteúdos das cadeias de caracteres cadeial e cadeia2. À cadeia de caracteres resultante da con- 
catenação é armazenada na cadeia3. A concatenação pode ser feita também pelo sinal de +. 


Outros exemplos de concatenação de cadeias podem ser encontrados em: 
YEXEMPLOSICAPINPASCADEXEMP3.PAS. 


9.1.4 Comparando cadeias de caracteres 


À comparação entre cadeias de caracteres é feita pelo sinal de igual, lembrando que letras maiúsculas 
são diferentes de letras minúsculas. 


IF cadeial = cadeia2 
THEN WRITELN('Cadeias iguais') 
ELSE WRITELN('Cadeias diferentes'); 


IF cadeial = “AULA” 
THEN WRITELN('A variável cadeial contém os caracteres AULA!) 
ELSE WRITELN('A variável cadeial contém outros caracteres'); 


Outros exemplos de comparação de cadeias de caracteres podem ser encontrados em: 
YEXEMPLOSICAPANPASCALEXEMPA.PAS e IEXEMPLOSICAPNPASCALEXEMPS.PAS. 
9.1.5 Descobrindo o número de caracteres de uma cadeia 
tamanho := LENGTH(cadeia); 


A função LENGTH retorna, para a variável tamanho, o número de caracteres da cadeia. A variável ta- 
manho pode ser do tipo Integer ou Real. 


Um exemplo da função LENGTH pode ser encontrado em: 
YEXEMPLOSICAPINPASCANDEXEMPso.PAS. 


9.1.6 Verificando a posição de uma cadeia de caracteres dentro de outra cadeia de caracteres 
posi := POS(cadeial,cadeia2); 


A função Pos retorna, para a variável posi, a posição inicial em que a cadeial aparece dentro da ca- 
deia2. 

A primeira posição da uma cadeia é a posição um. Se a cadeial não aparece dentro da cadeia2, a 
função pos retornará zero. 


Um exemplo da função POS pode ser encontrado em: 
VEXEMPLOSICAPOPASCALEXEMP7.PAS. 


9.1.7 Apagando caracteres de uma cadeia de caracteres 


DELETE (cadeia, posição, número); 
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A função DELETE apaga da variável cadeia o número de caracteres estipulados, a partir da posição 
informada. 


Um exemplo da função DELETE pode ser encontrado em: 
YEXEMPLOSICAPINPASCANDEXEMPS.PAS. 


9.1.8 Inserindo caracteres em uma cadeia de caracteres 
INSERT (cadeial, cadeia2, posição); 
A função INSERT insere a cadeial na cadeia2, a partir da posição dada. 
Um exemplo da função INSERT pode ser encontrado em: 


VEXEMPLOSICAPAPASCANEXEMPO.PAS. 


9.1.9 Alterando os caracteres de uma cadeia de caracteres 


Não há uma função específica para alterar os caracteres de uma cadeia. Assim, a alteração requererá 
que os caracteres sejam acessados individualmente para receber os novos valores. O acesso é obtido por 
meio de um índice cujo valor começa em 1 e vai sendo incrementado até o final da cadeia. Logo, se desejar 
alterar o primeiro caractere da cadeia, bastará escrever CADEIA[1] := ʻA’; e será feita a alteração do pri- 
meiro caractere para A. 


Outros exemplos da alteração de caracteres de uma cadeia podem ser encontrados em: 
\EXEMPLOS\CAP9\ PASCAL\EXEMP10.PAS e EXEMPLOSCAPOPASCANEXEMP11.PAS. 


9.110 Descobrindo um caractere a partir do seu valor ASCII 
carac := CHR(número) ; 
A função CHR retorna para a variável carac, o caractere ASCII que é representado pelo número. 
Um exemplo da função CHR pode ser encontrado em 


VEXEMPLOSICAPAPASCANEXEMP12.PAS. 


9.1.11 Descobrindo o valor ASCII de um caractere 
valor := ORD(caractere); 


A função ORD retorna, para a variável valor, o valor numérico que representa o caractere na tabela 
ASCII. 


Um exemplo da função ORD pode ser encontrado em 
YEXEMPLOSICAPONPASCADEXEMP13.PAS. 


9.1.12 Descobrindo o caractere sucessor 
carac := SUCC(caractere); 
A função succ retorna, para a variável carac, o caractere sucessor do caractere na tabela ASCII. 
Um exemplo da função SUCC pode ser encontrado em: 


VEXEMPLOSICAPAPASCANEXEMP14.PAS. 


9.113 Descobrindo o caractere antecessor ou predecessor 


carac := PRED(caractere); 


A função PRED retorna, para a variável carac, o caractere antecessor ou predecessor do caractere na 
tabela ASCII. 
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Um exemplo da função PRED pode ser encontrado em: 
YEXEMPLOSICAPANPASCADEXEMP1S.PAS. 


9.1.14 Convertendo caracteres para maiúsculo 


UPCASE (caractere[posição]); 


A função UPCASE converte o caractere da posição especificada para maiúsculo. 


STRUPPER (cadeia de caracteres); 


A função STRUPPER converte a cadeia de caracteres para maiúsculo. Essa função exige a utilização 
da biblioteca STRINGS. 


900 Observação 


Em ambas as conversões, as letras acentuadas e o ç não são convertidos. 


Exemplos das funções UPCASE e STRUPPER podem ser encontrados em: 
\EXEMPLOS\CAP9\PASCAL\ EXEMP16.PAS e EXEMPLOSICAPAPASCANEXEMP17.PAS. 


9.1.15 Convertendo caracteres para minúsculo 


Não existe uma função correspondente à função UPCASE para converter caracteres de maiúsculo para 
minúsculo. Assim, a conversão é obtida somente por meio de cadeias de caracteres. 


STRLOWER (cadeia de caracteres); 


À função STRLOWER converte a cadeia de caracteres para minúsculo. Essa função exige a utilização 
da biblioteca STRINGS. 


QOQ Observação 


Em ambas as conversões, as letras acentuadas e o ç não são convertidos. 


9.1.16 Convertendo um valor numérico em caracteres 


STR(valor_numérico, cadeia_de_caracteres); 


A função STR converte o valor numérico para a cadeia de caracteres. 


Um exemplo da função STR pode ser encontrado em: 
VEXEMPLOSICAPAPASCALEXEMP18.PAS. 


9.1.17 Convertendo caracteres em valor numérico 
VAL(cadeia de caracteres, valor numérico, erro); 


A função VAL converte o conteúdo de cadeia de caracteres para O valor numérico. Se ocorrer al- 
gum erro durante a conversão, a variável erro receberá um valor diferente de zero. 


Um exemplo da função VAL pode ser encontrado em: 
VEXEMPLOSICAPOPASCALEXEMP19.PAS. 


9.2 Manipulando cadeias de caracteres em C/C++ 


A linguagem C não possui um tipo de dado similar à sTRING da linguagem PASCAL. Em vez disso, para 
armazenar uma cadeia de caracteres, utiliza vetores (matrizes unidimensionais), nos quais cada posição re- 
presenta um caractere. À linguagem C++ possui o tipo String, mas seu estudo está fora do escopo deste livro. 
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É importante ressaltar que os compiladores da linguagem C/C++ identificam o fim de uma cadeia por 
meio do caractere nulo, ou seja, por meio de “0”. Sendo assim, deve-se declarar sempre o vetor com uma 
posição a mais para armazenar o caractere nulo (esse caractere não precisa ser armazenado manualmente; 
isso é feito automaticamente quando ocorre a leitura de uma string ou quando ocorre uma atribuição). Por 
exemplo, para armazenar a palavra CADEIA, deve-se declarar um vetor do tipo char com sete posições 
(que ocuparão posições contíguas na memória). 


char palavra[7]; 


índice 3 O 1 2 3 4 5 6 
valor a C A D E l A NO 
posição memória | ... 863 | 864 | 865 | 866 867 868 | 869 


Como se pode observar na tabela, a variável palavra, quando é declarada, pode ocupar qualquer 
posição disponível na memória; entretanto, todas as posições do vetor ocupam espaços de memória adja- 
centes, e cada caractere ocupa 1 byte. Por isso, pelo exemplo, se a letra C estiver armazenada na posição 
de memória de endereço 863 (e esse endereço equivale a 1 byte), a letra A deverá ocupar o endereço 864 e 
assim por diante. 

Os caracteres armazenados em uma cadeia devem estar entre aspas e, quando apóstrofos, aspas ou 
barras invertidas fizerem parte da cadeia de caracteres, deverão ter uma barra invertida antecedendo-os. 


Exemplos de variáveis do tipo cadeia de caracteres: 


char NOME[21]; A variável NoME poderá armazenar até vinte caracteres. 
char SEXO[4]; À variável sexo poderá armazenar até três caracteres. 
char CURSO; À variável curso poderá armazenar apenas um caractere. 


Para manipular as cadeias de caracteres na linguagem C, devem-se utilizar funções específicas, e estas 
fazem parte da biblioteca string.h. 


9.2.1 Inicializando cadelas de caracteres 


As variáveis que armazenam cadeias de caracteres podem ser inicializadas automaticamente pelo programa 
ou podem receber um valor por meio do teclado. A seguir, exemplificamos alguns casos. 


a) Inicialização no momento da declaração 


char nome [ ] = LIPAT Eid aa SOn d a A BN Eme SE yy ANOLE 
ou 
char nome[ ] = “Programa”; 


No primeiro caso, a variável nome recebeu as letras separadamente (inclusive o caractere nulo). Por 
isso, cada uma das letras estava entre apóstrofos (‘ °) — esta é a maneira de identificar um caractere isola- 
damente. 

No segundo caso, a variável nome foi inicializada com uma palavra, recebendo automaticamente o 
caractere nulo. Por isso, a palavra Programa estava entre aspas (“ ”) — esta é a maneira de identificar uma 
cadeia de caracteres. 

Em ambos os casos, não houve necessidade de expressar o número de posições dentro dos colchetes, 
pois esse número é definido automaticamente em função da inicialização. 

Os exemplos a seguir mostram como armazenar uma barra invertida e um apóstrofo em cadeias sem 
gerar erros de compilação. 


char local[]="c: NNexemplosNXarquivo.txt”; 
char texto[]="curso dN'água”; 


No primeiro caso, a variável local receberá a cadeia c: XexemplosYarquivo.txt . No segundo caso, a 
variável texto receberá a cadeia curso d'água. 
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b) Inicialização por meio da atribuição (depois da declaração) 


char vet1[10], vet2[5]; 
strcpy(vetl, “Programa”); 


ou 
strcpy (vetl, vet2); 


No primeiro caso, a variável vet1 recebe um valor constante (a palavra Programa). No segundo caso, 
o conteúdo da variável vet2 é copiado na variável vet1. 


c) Inicialização por meio do teclado 


char vet [10]; 
scanf(“$s%*c”,&vet); 


O comando scanf consegue armazenar valores vindos do teclado. No caso de uma cadeia de carac- 
teres, esse comando consegue armazenar todos os símbolos digitados até a ocorrência do primeiro espaço 
em branco. Por exemplo, se for digitado o nome Maria da Silva, a variável vet armazenará apenas Maria 
(o que vem depois do espaço em branco é perdido). Para resolver esse problema, utiliza-se a função gets. 


gets(vet); 


À função gets armazena na variável vet todos os símbolos digitados até a ocorrência do ENTER. 


9.2.2 Copiando cadeias de caracteres 


strcpy(strl, str2); 


A função strcpy copia a cadeia str2 para a cadeia str1. Essa função exige a utilização da biblioteca 
string.h. 


strncpy(strl, str2, n); 


À função strncpy copia os n primeiros caracteres da cadeia str2 para a cadeia str1. Essa função exige 
a utilização da biblioteca string.h. 


Exemplos das funções strcpy e strncpy podem ser encontrados em: 
WEXEMPLOSICAPAC+HEXEMP1.CPP e EXEMPLOSCAPAC+HEXEMP2.CPP, 


9.2.3 Concatenando cadeias de caracteres 
strcat (cadeial,cadeia2); 
A função strcat concatena a cadeia? à cadeial. Essa função exige a utilização da biblioteca string.h. 
strncat (cadeial,cadeia2, n); 


A função strncat concatena os n primeiros caracteres da cadeia2 à cadeial. Essa função exige a uti- 
lização da biblioteca string.h. 


Exemplos das funções strcat e strncat podem ser encontrados em: 
VEXEMPLOSICAPAC+HEXEMP3.CPP, 


9.2.4 Comparando cadeias de caracteres 


resultado = strcmp(cadeial, cadeia2); 
A função strcmp compara duas cadeias de caracteres e retorna um número inteiro, que poderá ser: 
zero se as duas cadeias forem iguais; 
um número menor que zero se a cadeial for alfabeticamente menor que a cadeia2; 


um número maior que zero se a cadeial for alfabeticamente maior que a cadeia2. 


Essa função considera letras maiúsculas símbolos diferentes de letras minúsculas. 
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resultado = 


stricmp(cadeial, cadeia2); 
resultado = 


strcmpi(cadeial, cadeia2); 


As funções stricmp e strempi comparam duas cadeias de caracteres e retornam um número inteiro, 
que poderá ser: 
zero se as duas cadeias forem iguais; 


um número menor que zero se a cadeial for alfabeticamente menor que a cadeiaz; 


um número maior que zero se a cadeial for alfabeticamente maior que a cadeia2. 


Essas funções consideram letras maiúsculas e minúsculas símbolos iguais e não fazem parte do padrão ANSI. 


resultado = strncmp(cadeial, cadeia2, n); 


À função strncmp compara duas cadeias de caracteres da primeira posição, ou seja, da posição zero até 
a posição n ou até encontrar alguma diferença, e retorna um número inteiro, que poderá ser: 
zero se as duas cadeias forem iguais; 
um número menor que zero se a cadeial for alfabeticamente menor que a cadeia2; 
um número maior que zero se a cadeial for alfabeticamente maior que a cadeia2. 
Essa função considera letras maiúsculas símbolos diferentes de letras minúsculas. 


resultado = strnicmp(cadeial, cadeia2, n); 
resultado = strncmpi(cadeial, cadeia2, n); 


As funções strnicmp e strncmpi comparam duas cadeias de caracteres da primeira posição, ou seja, 
da posição zero até a posição n, ou até encontrar alguma diferença, e retornam um número inteiro, que 
poderá ser: 


zero se as duas cadeias forem iguais; 


um número menor que zero se a cadeial for alfabeticamente menor que a cadeiaz; 


um número maior que zero se a cadeial for alfabeticamente maior que a cadeia2. 


Essas funções consideram letras maiúsculas e minúsculas símbolos iguais e não fazem parte do padrão ANSI. 
As funções strcmp, stricmp, strcmpi, strncmp, strnicmp € strncmpi exigem o uso da biblioteca 
string.h. 


Exemplos das funções de comparação de cadeias podem ser encontrados em: 
YEXEMPLOSCAPAC++ EXEMP4.CPP e JEXEMPLOSCAPAC+HEXEMP5.CPP. 
9.2.5 Descobrindo o número de caracteres de uma cadeia 


tamanho = strlen(cadeia); 


À função strlen retorna para a variável tamanho o número de caracteres da cadeia. Essa função exige 
a utilização da biblioteca string.h. 


Um exemplo da função strlen pode ser encontrado em: 
WEXEMPLOSICAPAC+HEXEMP6.CPP, 


200 


Observação 


O caractere que indica final de cadeia de caracteres, '\0', não entra no total de ca- 
racteres da cadeia. 


9.2.6 Verificando a posição de uma cadeia de caracteres dentro de outra cadeia de caracteres 


posi = strchr(strl, ch); 
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À função strchr retorna para a variável posi um ponteiro com a posição da cadeia str1, em que o carac- 
tere ch é encontrado pela primeira vez. Se o caractere ch não for encontrado na cadeia str1, a variável posi 
receberá null. Essa função exige a utilização da biblioteca string.h. 


posi = strrchr(strl, ch); 


À função strrchr retorna para a variável posi um ponteiro com a posição da cadeia str1, em que o ca- 
ractere ch é encontrado pela última vez. Se o caractere ch não for encontrado na cadeia str1, a variável posi 
receberá null. Essa função exige a utilização da biblioteca string.h. 


posi = strstr(strl, str2); 


A função strstr retorna para a variável posi um ponteiro com a posição da cadeia str1, na qual a ca- 
deia str2 é encontrada pela primeira vez. Se a cadeia str2 não for encontrada na cadeia str1,a variável posi 
receberá null. Essa função exige a utilização da biblioteca string.h. 

Essas funções fazem distinção entre letras maiúsculas e minúsculas. 


Exemplos das funções strchr, strstr e strrchr podem ser encontrados em: 


VEXEMPLOSICAPAC++ EXEMP7.CPP. 


9.2.7 Apagando caracteres de uma cadeia de caracteres 


Não existe uma função pronta para apagar caracteres de uma cadeia na linguagem C/C++, mas com 
alguma programação isso é possível. 


Um exemplo de programação que apaga caracteres de uma cadeia pode ser encontrado em: 
\EXEMPLOS\ CAPAC+HEXEMPB.CPP. 


92.8 Inserindo caracteres em uma cadeia de caracteres 


Não existe uma função pronta para inserir caracteres em uma cadeia na linguagem C/C++, mas com 
alguma programação isso é possível. 


Um exemplo de programação que insere caracteres em uma cadeia pode ser encontrado em: 


WEXEMPLOSICAPAC+HEXEMP9.CPP. 


9.2.9 Alterando os caracteres de uma cadela de caracteres 
strset(strl, ch); 


A função strset substitui todos os caracteres da cadeia str1 pelo caractere ch. Essa função exige a 
utilização da biblioteca string.h e não faz parte do padrão ANSI. 
strnset(strl, ch, n); 
A função strnset substitui os n primeiros caracteres da cadeia str1 pelo caractere ch. Essa função 
exige a utilização da biblioteca string.h e não faz parte do padrão ANSI. 


strrev(strl); 


A função strrev inverte todos os caracteres da cadeia str1. Essa função exige a utilização da biblioteca 
string.h e não faz parte do padrão ANSI. 

Além das funções anteriores, os caracteres de uma cadeia podem ser acessados por sua posição. Assim, 
se desejar alterar o primeiro caractere da cadeia, basta escrever CADEIA[0] = ʻA’, e será feita a alteração. 


Exemplos de alterações de caracteres de cadeias podem ser encontrados em: 
WEXEMPLOSCAPAC++ EXEMP10.CPP, EXEMPLOSICAPAC+HEXEMP11.CPP e 
VEXEMPLOSICAPAC+HEXEMP12.CPP, 


9.210 Descobrindo um caractere a partir do seu valor ASCII 


caractere = int (número); 


A função int retorna para a variável caractere o caractere ASCII, que é representado pelo número. 
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Um programa que descobre um caractere a partir de seu valor ASCII pode ser encontrado em: 
WEXEMPLOSCAPAC+HEXEMP13.CPP, 


9.2.11 Descobrindo o valor ASCII de um caractere 
valor = toascii(caractere); 


A função toascii retorna para a variável valor o valor numérico que representa o caractere na ta- 
bela ascrr. Essa função exige a utilização da biblioteca ctype.h. 


Um programa que descobre o valor numérico de um caractere na tabela ASCII pode ser encontrado em: 
WEXEMPLOSCAPAC+HEXEMP14.CPP,. 


9.2.12 Descobrindo o caractere sucessor 


Não existe uma função específica para descobrir o caractere sucessor, mas, somando uma unidade ao 
caractere, o sucessor será obtido. 


Um exemplo pode ser encontrado em: 
YEXEMPLOSCAPAC+HEXEMP1S.CPP. 


9.2.13 Descobrindo o caractere antecessor ou predecessor 


Não existe uma função específica para descobrir o caractere antecessor, mas, retirando uma unidade do 
caractere, o antecessor será obtido. 


Um exemplo pode ser encontrado em: 
WEXEMPLOSICAPAC+HEXEMP1 6.CPP, 


9.2.14 Convertendo caracteres para maiúsculo 
cadeia[posição] = toupper(cadeia[posição]); 


À função toupper converte o caractere da cadeia da posição especificada para maiúsculo. Essa função 
exige a utilização da biblioteca ctype.h. 


strupr (cadeia); 


A função strupr converte todos os caracteres da cadeia para maiúsculo. Essa função exige a utilização 
da biblioteca string.h e não faz parte do padrão ANSI. 


Exemplos das funções toupper e strupr podem ser encontrados em: 
WEXEMPLOSICAPAC++ EXEMP17.CPP, 


se e Observação 


Em ambas as conversões, as letras acentuadas e o ç não são convertidos. 


9.2.15 Convertendo caracteres para minúsculo 
cadeia[posição] = tolower(cadeia[posição]); 


À função tolower converte o caractere da cadeia da posição especificada para minúsculo. Essa função 
exige a utilização da biblioteca ctype.h. 


strlwr (cadeia); 


À função strlwr converte todos os caracteres da cadeia para minúsculo. Essa função exige a utilização 
da biblioteca string.h e não faz parte do padrão ANSI. 


Exemplos das funções tolower e strlwr podem ser encontrados em: 


WEXEMPLOSICAPAC++ EXEMP1 8.CPP. 
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GO Observação 


Em ambas as conversões, as letras acentuadas e o ç não são convertidos. 


2.16 Convertendo um valor numérico em caractere 


itoa(valor numérico inteiro, cadeia de caracteres, base); 


À função itoa converte o valor numérico inteiro para a cadeia de caracteres, utilizando a base 
especificada. Essa função exige a utilização da biblioteca stalib.h. Nessa função, o valor numérico in- 
teiro deve estar armazenado em uma variável do tipo int. A variável que armazenará a conversão, ca- 
deia de caracteres, deverá suportar o tamanho do número, incluindo o caractere de final da cadeia, ou 
seja, \0, e a base numérica de conversão deverá estar entre 2 e 36. O retorno dessa função pode ser de até 
17 bytes. 


ltoa(valor numérico inteiro, cadeia de caracteres, base); 


A função ltoa converte O valor numérico inteiro para a cadeia de caracteres utilizando a base 
especificada. Essa função exige a utilização da biblioteca stalib.h. Nessa função, o valor numérico in- 
teiro deve estar armazenado em uma variável do tipo long. A variável que armazenará a conversão, ca- 
deia de caracteres, deverá suportar o tamanho do número, incluindo o caractere de final da cadeia, ou 
seja, \0, e a base numérica de conversão deverá estar entre 2 e 36. O retorno dessa função pode ser de até 
33 bytes. 


ultoa(valor numérico inteiro, cadeia de caracteres, base); 


A função ultoa converte o valor numérico inteiro para a cadeia de caracteres, utilizando a 
base especificada. Essa função exige a utilização da biblioteca stalib.h. Nessa função, o valor numéri- 
co inteiro deve estar armazenado em uma variável do tipo unsigned long. A variável que armazenará a 
conversão, cadeia de caracteres, deverá suportar o tamanho do número, incluindo o caractere de final 
da cadeia, ou seja, \0, e a base numérica de conversão deverá estar entre 2 e 36. O retorno dessa função 
pode ser de até 33 bytes. 


texto = ecvt (valor numérico real, 
quantidade de dígitos significativos, 
quantidade de dígitos decimais, 
sinal); 


A função ecvt converte o valor numérico real e atribui a conversão à variável texto utilizando a 
quantidade de dígitos significativos especificada, ou seja, todos os números digitados serão conta- 
dos e os espaços à direita serão completados com zeros até atingir a quantidade de dígitos signifi- 
cativos especificada. Essa função atribui à variável quantidade de dígitos decimais a quantidade de 
dígitos decimais anteriores à conversão. Atribui também à variável sinal zero se o número a ser convertido 
for positivo, ou um, se for negativo. Essa função exige a utilização da biblioteca stdlib.h. Nessa função, 
o valor numérico deverá estar armazenado em uma variável do tipo double. A variável que armazenará a 
conversão deverá suportar o tamanho do número, incluindo o caractere de final da cadeia, ou seja, NO. Essa 
função não trabalha com aproximações. 


texto = fcvt(valor numérico real, 
quantidade de dígitos significativos, 
quantidade de dígitos decimais, 
sinal); 


A função fevt converte o valor numérico real e atribui a conversão à variável texto utilizando a quan- 
tidade de dígitos significativos especificada, ou seja, os dígitos fracionários serão contados e os espaços 
à direita serão completados com zeros até atingir a quantidade de dígitos significativos. Essa função 
atribui à variável quantidade de dígitos decimais a quantia de dígitos decimais anteriores à conversão e à 
variável sinal zero se o número a ser convertido for positivo, ou um, se for negativo. Essa função exige a utili- 
zação da biblioteca stdlib.h. Nessa função, o valor numérico real deve estar armazenado em uma variável 
do tipo double. À variável que armazenará a conversão deverá suportar o tamanho do número, incluindo o 
caractere de final da cadeia, ou seja, WO. Essa função trabalha com aproximações. 
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Exemplos de conversões de valores numéricos para caracteres podem ser encontrados em: 
\EXEMPLOS\ CAPAC+HEXEMP1 9.CPP e EXEMPLOSCAPAC+HEXEMP20.CPP. 
As funções descritas nesta seção não fazem parte do padrão ANSI. 


9.2.17 Convertendo caracteres em valor numérico 


numero = atoi(cadeia de caracteres); 


A função atoi converte a cadeia de caracteres para um valor numérico inteiro, ou seja, a parte 
fracionária será desprezada. A variável numero deve ser do tipo int e a função atoi exige a utilização da 
biblioteca stdlib.h. 


numero = atol(cadeia de caracteres); 


A função atol converte a cadeia de caracteres para um valor numérico inteiro, ou seja, a parte 
fracionária será desprezada. A variável numero deve ser do tipo long e a função atol exige a utilização da 
biblioteca stdlib.h. 


numero = atof(cadeia de caracteres); 


A função atof converte a cadeia de caracteres para um valor numérico real. A variável numero deve 
ser do tipo float e a função atof exige a utilização da biblioteca stdlib.h. 


numero = strtod(cadeia de caracteres, &erro); 


A função strtod converte a cadeia de caracteres para um valor numérico real. A variável numero 
deve ser do tipo double. A variável erro receberá um valor diferente de null se algum erro ocorrer na 
conversão; logo, essa variável deve ser um ponteiro do tipo char. A função strtod exige a utilização da 
biblioteca stdlib.h. 


numero = strtol(cadeia de caracteres, &erro, base); 


A função strtol converte a cadeia de caracteres para um valor numérico inteiro, ou seja, a parte 
fracionária será desprezada. A variável numero deve ser do tipo long. À variável erro receberá um valor 
diferente de nul1 se algum erro ocorrer na conversão; logo, essa variável deve ser um ponteiro do tipo char. 
A variável base permite que a base de conversão seja escolhida, ou seja, uma base numérica entre 2 e 36. A 
função strtol exige a utilização da biblioteca stdlib.h. 


Exemplos de conversões de cadeias de caracteres em valores numéricos podem ser encontrados em: 


VEXEMPLOSICAPAC+HEXEMP21.CPP. 


9.3 Manipulando cadeias de caracteres em JAVA 


As cadeias de caracteres em JAVA podem ser armazenadas em objetos da classe string e da classe 
StringBuffer. As cadeias de caracteres devem estar entre aspas, enquanto os caracteres devem estar entre 
apóstrofos. 


Exemplos: 

String nome; À variável nome poderá armazenar uma cadeia de caracteres. 

char letra; À variável letra poderá armazenar um único caractere. 

StringBuffer texto; À variável texto poderá armazenar uma cadeia de caracteres que, inicial- 


mente, tem tamanho 16, expansível de acordo com a necessidade. 


Para armazenar apóstrofos na cadeia de caracteres, basta colocá-los entre contrabarras. 

Por exemplo, para escrever CURSO D'ÁGUA, faça: System.out.println(“CURSO DV'NÁGUA"). 

A manipulação de cadeias de caracteres na linguagem JAVA utiliza o pacote de classes java.lang. Al- 
guns métodos das classes desse pacote são descritos a seguir. Esse pacote de classes contém funcionalidades 
básicas da linguagem JAVA e, por isso, dispensa o uso de import. 


9.3.1 Inicializando cadelas de caracteres 


As variáveis que armazenam cadeias de caracteres podem ser inicializadas automaticamente pelo programa 
ou podem receber um valor por meio do teclado. A seguir, exemplificamos alguns casos. 
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a) Inicialização no momento da declaração 
String textol = new String(); 

No exemplo anterior, o objeto texto1 foi instanciado e seu conteúdo será vazio. 
String texto2 = new String (“PROGRAMA”); 


No exemplo anterior, o objeto texto2 foi instanciado e seu conteúdo será o conjunto de caracteres 
PROGRAMA. Um conjunto de caracteres é sempre acompanhado por aspas. 


char texto [] f'c! 7 'o! E "m' 7 'p' : ru’ i rr A 'a! A 'd' : "o! ç EUA Es 
String texto3 = new String (texto); 
No exemplo anterior, a variável texto recebeu as letras separadamente. Por isso, cada uma das letras 
estava acompanhada por apóstrofos — esta é a maneira de identificar um caractere isoladamente. Em segui- 
da, o objeto texto3 foi instanciado e seu conteúdo será o conjunto de caracteres computador. 


String texto4 = new String (texto,7,3); 


No exemplo anterior, o objeto texto4 foi instanciado e seu conteúdo será o conjunto de caracteres da 
variável texto, a partir da sétima posição e com três caracteres, ou seja, se texto contém a cadeia compu- 
tador, texto4 receberá apenas “dor”. 


StringBuffer texto5 = new StringBuffer(); 


No exemplo anterior, o objeto texto5 foi instanciado, seu conteúdo será vazio e sua capacidade inicial 
será de 16 caracteres. 


StringBuffer texto6 = new StringBuffer(10); 


No exemplo anterior, o objeto texto6 foi instanciado, seu conteúdo será vazio e sua capacidade inicial 
será de 10 caracteres. 


StringBuffer texto7 = new StringBuffer (“valor”); 


No exemplo anterior, o objeto texto7 foi instanciado e seu conteúdo será “valor”. 


b) Inicialização por meio da atribuição (depois da declaração) 


String textol = new String(); 

textol = “aula”; 

String texto2 = new String(); 

String texto3 = new String(“programa”); 
texto2 = texto3; 


No primeiro caso, o objeto texto1 recebe um valor constante, a cadeia de caracteres aula. No segundo 
caso, o objeto texto2 terá o mesmo conteúdo de texto3, ou seja, “programa”. 


c) Inicialização por meio do teclado 


String cadeia = new String(); 

Scanner entrada; 

entrada = new Scanner (System. in); 
System.out.println(“Digite uma cadeia de caracteres: “); 
cadeia = entrada.next(); 


O método next consegue armazenar valores vindos do teclado. No caso de uma cadeia de caracteres, 
esse método consegue armazenar todos os símbolos digitados até a ocorrência do primeiro espaço em bran- 
co. Por exemplo, se for digitado o nome Maria da Silva, a variável cadeia armazenará apenas Maria (o que 
vem depois do espaço em branco é perdido). Para resolver esse problema, utiliza-se o método nextLine(). 


String cadeia = new String(); 
StringBuffer nome = new StringBuffer(); 
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Scanner entrada; 

entrada = new Scanner(System.in); 
System.out.println(“Digite uma cadeia de caracteres: “); 
cadeia = entrada.nextLine(); 

nome .append(cadeia); 


Os objetos da classe StringBuffer não podem ser carregados pelo teclado com os métodos da classe Scan- 
ner. Assim, o conteúdo do teclado deve ser carregado em um objeto da classe string pelo método nextLine() 
e posteriormente atribuído a um objeto da classe stringBuffer. 


9.3.2 Copiando cadeias de caracteres 
strl=str2; 


A variável str1, que é do tipo String, terá o mesmo conteúdo da variável str2, que também é do tipo 
String. 


strl = str2.substring(posição inicial); 


O método substring copia o conteúdo da variável str2, a partir da posição inicial até o fim da 
cadeia, para a variável strl. 


strl = str2.substring(posição inicial, posição final); 


O método substring copia o conteúdo da variável str2, a partir da posição inicial até posição . 
final - 1 da cadeia, para a variável strl. 


strl.append(str2); 


O método append acrescenta o conteúdo da variável str2 ao final da variável str1, e strl e str2 
devem ser do tipo stringBuffer. 


strl.append(str2, posição inicial, posição final); 


O método append acrescenta o conteúdo da variável str2, a partir da posição inicial até a posi- 
ção final — 1, ao final da variável str1, sendo que strl e str2 devem ser do tipo StringBuffer. 


Exemplos de cópias de caracteres podem ser encontrados em: 
\EXEMPLOS\CAP9\JAVA\EXEMP!1.java. 


9.3.3 Concatenando cadeias de caracteres 
SEEI = GRSA so SCEO SP e qr RE 


À concatenação de cadeias de caracteres pode ser feita com o sinal de +. A str1 receberá a concatena- 
ção das cadeias str2, str3,... € strN. 


strl = str2.concat(str3); 


O método concat concatena a cadeia str2 com a cadeia str3 e atribui essa concatenação à cadeia 
strl. 


Exemplos de concatenação de cadeias de caracteres podem ser encontrados em: 
\EXEMPLOS\CAP9\JAVA\EXEMP?2.java. 


9.3.4 Comparando cadeias de caracteres 


cadeial.equals(cadeia2) 


O método equals compara duas cadeias de caracteres e retorna true se elas forem iguais, ou false se 
forem diferentes. Esse método considera letras maiúsculas símbolos diferentes de letras minúsculas. 


cadeial.equalsIgnoreCase(cadeia2) 


O método equalsIgnorecase compara duas cadeias de caracteres e retorna true se elas forem iguais, 
ou false se forem diferentes. Esse método considera letras maiúsculas e minúsculas símbolos iguais. 
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resultado = cadeial.compareTo(cadeia2); 


O método compareTo compara duas cadeias de caracteres e retorna um número inteiro, que poderá ser: 
zero, se as duas cadeias forem iguais; 
um número menor que zero, se a cadeial for alfabeticamente menor que a cadeiaz; 


um número maior que zero, se a cadeial for alfabeticamente maior que a cadeia2. 
Esse método considera letras maiúsculas símbolos diferentes de letras minúsculas. 


cadeial.regionMatches (true ou false, inicial cadeial, cadeia2, inicial cadeia2, quantidade) 


O método regionMmatches compara partes de duas cadeias de caracteres e retorna true se elas forem 
iguais, ou false se forem diferentes. A sequência de parâmetros significa: 


O true quando se deseja que a diferença entre letras maiúsculas e minúsculas seja ignorada, e o 
false quando se deseja que a diferença seja mantida. 


O inicial cadeial é a posição inicial da cadeial em que a comparação será iniciada. 
À cadeia? é a cadeia que será comparada com a cadeial. 

O inicial cadeia? é a posição inicial da cadeia2 em que a comparação será iniciada. 
À quantidade é a quantidade de caracteres que serão comparados. 


cadeial.startsWith(cadeia2) 
cadeial.startsWith(cadeia2, posição) 


O método startswith compara se a cadeial começa com os mesmos caracteres da cadeia2 . Quando 
a posição é especificada, a comparação é iniciada a partir da especificação. Esse método considera letras 
maiúsculas símbolos diferentes de letras minúsculas. Esse método retorna true ou false. 


cadeial.endsWith(cadeia2) 


O método endswith compara se a cadeial termina com os mesmos caracteres da cadeia2. Esse mé- 
todo considera letras maiúsculas símbolos diferentes de letras minúsculas. Esse método retorna true ou 
false. 


Exemplos com comparações entre cadeias de caracteres podem ser encontrados em: 
\EXEMPLOS\CAP9\ JAVAEXEMPS3 java. 


9.3.5 Descobrindo o número de caracteres de uma cadela 


tamanho = cadeia.length(); 


O método length retorna para a variável tamanho o número de caracteres da cadeia. 


Um exemplo do método length pode ser encontrado em: 
WEXEMPLOSICAPOJAVAEXEMPA java. 


9.3.6 Verificando a posição de uma cadeia de caracteres dentro de outra cadeia de caracteres 
posi = cadeial.indexOf (cadeia2); 


O método indexof retorna a posição a partir da qual a cadeia? aparece pela primeira vez na cadeial. 
À comparação começará da posição zero da cadeial até encontrar a primeira ocorrência. Se a cadeia? não 
existir na cadeial, o retorno será -1. 


posi = cadeial.indexOf (cadeia2, posição); 


O método indexof retorna a posição a partir da qual a cadeia2 aparece pela primeira vez na cadeial. 
À comparação começará da posição especificada da cadeial até encontrar a primeira ocorrência. Se a ca- 
deia2 não existir na cadeial, o retorno será -1. 


posi = cadeial.lastIndexoOf (cadeia2); 


O método lastIndexof retorna a posição a partir da qual a cadeia? aparece pela última vez na ca- 
deial. Se a cadeia2 não existir na cadeial, o retorno será -1. 
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posi = cadeial.lastIndexoOf (cadeia2, posição); 


O método lastIndexof retorna à posição a partir da qual a cadeia? aparece pela última vez na ca- 
deial. A comparação começará da posição especificada da cadeial. Se a cadeia? não existir na cadeial, 
o retorno será —1. 

Esses métodos fazem distinção entre letras maiúsculas e minúsculas. 


Exemplos dos métodos indexof e last Indexof podem ser encontrados em: 
WEXEMPLOSICAPNJAVAY EXEMPS java. 


9.3.7 Apagando caracteres de uma cadeia de caracteres 


Para apagar o conteúdo de uma cadeia de caracteres, é necessário utilizar objetos da classe stringBuffer, 
ou seja, objetos que armazenam cadeias de caracteres cujo tamanho de memória ocupado pode variar de 
acordo com a necessidade. 


cadeia.delete(posição inicial, posição final); 


O método delete apaga os caracteres existentes da posição inicial até a posição final-1 da ca- 
deia. 


Um exemplo do método delete pode ser encontrado em: 
\EXEMPLOS\CAP9\JAVA\EXEMP6.java. 


9.3.8 Inserindo caracteres em uma cadeia de caracteres 


Para inserir conteúdo em uma cadeia de caracteres, é necessário utilizar objetos da classe String 
Buffer, ou seja, objetos que armazenam cadeias de caracteres cujo tamanho de memória ocupado pode 
variar de acordo com a necessidade. 


cadeial.insert (posição, cadeia2); 
O método insert insere os caracteres da cadeia2, na cadeial, a partir da posição especificada. 


Um exemplo do método insert pode ser encontrado em: 
WEXEMPLOSICAPNJAVAEXEMP? java. 


9.3.9 Alterando os caracteres de uma cadela de caracteres 


strl.replace(str2, str3); 


O método replace procura todas as ocorrências de str2, dentro da cadeia str1, substituindo-as por 
str3. 


strl.replaceAll(str2, str3); 


O método replaceA11 procura todas as ocorrências de str2, dentro da cadeia str1, substituindo-as 
por str3. Não existe diferença entre os métodos replace e replaceall. 


strl.replaceFirst(str2, str3); 


O método replaceFirst procura a primeira ocorrência de str2, dentro da cadeia str1, substituindo-a 
por str3. 


strl.split(”“separador”"); 


O método split separa o conteúdo da cadeia strl1 em várias cadeias, utilizando o separador para 
determinar onde começa e termina cada nova cadeia gerada. 


strl.trim(); 
O método trim retira os espaços em branco do início e do fim da cadeia str1. 
char novo[] = texto.toCharArray(); 


O método tochararray coloca cada caractere da cadeia texto em uma posição de um vetor do tipo 
char. 
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caractere = texto.charAt (posição); 


O método charat retorna para a variável caractere o caractere da posição especificada da cadeia 
texto. 


texto.setCharAt (posição, caractere); 
O método setCharat substitui o caractere da posição especificada da cadeia texto por caractere. 
texto.reverse(); 


O método reverse inverte os caracteres da cadeia texto. 
Exemplos dos métodos replace, replaceAl1, replaceFirst, split, trim, toCharArray, charAt, se- 
tCharAt e reverse podem ser encontrados em: 


WEXEMPLOSICAP9JAVAEXEMPS java 
WEXEMPLOSICAP9NJAVAEX EMP) java 
WEXEMPLOSICAP9JAVAEXEMP10.java 


9.3.10 Descobrindo um caractere a partir do seu valor ASCII 
caractere = char (número) ; 
O método char retorna, para a variável caractere, o caractere ASCII correspondente ao número. 
Um exemplo do método char pode ser encontrado em: 


\EXEMPLOS\CAP9\JAVA\EXEMP11.java. 


9.3.11 Descobrindo o valor ASCII de um caractere 
numero = int(caractere); 


O método int retorna, para a variável numero, o valor numérico que representa o caractere na tabela 
ASCII. 


Um exemplo do método int pode ser encontrado em: 
\EXEMPLOS\CAP9\JAVA\EXEMP12.java. 


9.3.12 Descobrindo o caractere sucessor 


Não existe um método específico para descobrir o caractere sucessor, mas, somando uma unidade ao 
caractere, obtém-se o seu sucessor. 


Um exemplo pode ser encontrado em: 
WEXEMPLOSICAPOJAVAEXEMPI13.java. 


9.3.13 Descobrindo o caractere antecessor ou predecessor 


Não existe um método específico para descobrir o caractere antecessor, mas, retirando uma unidade do 
caractere, obtém-se o seu antecessor. 


Um exemplo pode ser encontrado em: 
\EXEMPLOS\CAP9JAVA\EXEMP14.java. 


9.3.14 Convertendo caracteres para maiúsculo 


cadeia.toUpperCase(); 
O método touppercase converte todos os caracteres da cadeia para maiúsculo. 


Um exemplo do método touppercase pode ser encontrado em: 
WEXEMPLOSICAPOJAVAEXEMPIS java. 


9.3.15 Convertendo caracteres para minúsculo 


cadeia.toLowerCase(); 
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O método toLowerCase converte todos os caracteres da cadeia para minúsculo. 


Um exemplo do método toLowerCase pode ser encontrado em: 


WEXEMPLOSICAP9JAVAEXEMP16.java. 


9.3.16 Convertendo um valor numérico em caractere 
cadeia = String.valueOf(valor numérico); 


O método string.valueof converte o valor numérico para uma cadeia de caracteres e armazena essa 
conversão em cadeia. À variável cadeia deve ser do tipo String. 

O método string.valueof consegue converter números apenas para cadeias de caracteres. Para con- 
verter para apenas um caractere, é necessário utilizar o método Character. forDigit. 


caractere = Character.forDigit (valor numérico, base); 


O método character. forDigit converte o valor numérico para um caractere utilizando a base nu- 
mérica especificada e armazena essa conversão em caractere. A variável caractere deve ser do tipo char. 


Exemplos dos métodos String.valueOf e Character.forDigit podem ser encontrados em: 
WEXEMPLOSICAPONJAVAEXEMP17 java. 


9.3.17 Convertendo caracteres em valor numérico 


numero = Integer.parseInt(cadeia); 
O método Integer .parseInt() converte a cadeia para um valor numérico inteiro. À variável numero 
deve ser do tipo int. 
numero = Long. parseLong(cadeia); 
O método Long.parseLong() converte a cadeia para um valor numérico inteiro. A variável numero 
deve ser do tipo long. 
numero = Float.parseFloat (cadeia); 
O método Float.parseFloat() converte a cadeia para um valor numérico real. A variável numero 
deve ser do tipo float. 
numero = Double.parseDouble(cadeia); 
O método Double .parseDouble() converte a cadeia para um valor numérico real. A variável numero 
deve ser do tipo double. 
numero = Character.digit(caractere, base); 
O método character.digit() converte o caractere para um valor numérico inteiro, utilizando a 
base numérica especificada em base. A variável numero deve ser do tipo int. 


Exemplos de conversões de caracteres para valores numéricos podem ser encontrados em: 


\EXEMPLOS\ CAPIJAVAEXEMP18.java. 


EXERCÍCIOS RESOLVIDOS 


BEER Faça um programa que receba uma frase, calcule e mostre a quantidade de vogais da frase digitada. O 
programa deverá contar vogais maiúsculas e minúsculas. 
SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, pegando caractere por caractere. 
Comparar cada caractere com as vogais (maiúsculas e minúsculas). 


Quando encontrar uma vogal, acrescentar um na quantidade. 
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PASCAL, SOLUÇÃO: 
RE NEXERCACAP9NPASCALNEX1.PAS e NEXERCICAP9NPASCALNEX1.EXE 


C/C++ Sorução: 
\EXERC\CAP9\C++\EX1.CPP e \EXERC\CAP9\C++\EX1.EXE 


C 
E-Go- SoLução: 
CED \EXERC\CAP9\JAVA\EX1.java e \EXERC\CAP9\JAVA\EX1.class 


IFA Faça um programa que receba uma frase, calcule e mostre a quantidade de consoantes da frase digita- 
da. O programa deverá contar consoantes maiúsculas e minúsculas. 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, pegando caractere por caractere. 
Comparar cada caractere com as consoantes (maiúsculas e minúsculas). 


Quando encontrar uma consoante, acrescentar um na quantidade. 


PASCAL SOLUÇÃO: 
NEXERCACAP9NPASCALVEX2.PAS e NEXERCICAP9NPASCALNEX2.EXE 


Es 
Lona SoLução: 
ERES \EXERC\CAP9\C++\EX2.CPP e NEXERCICAP9NC++NEX2. EXE 


RELAIA SOLUÇÃO: 
E NEXERCICAP9NJAVANEX2. java e \EXERC\CAP9\JAVA\EX2.class 


IEA Faça um programa que receba uma frase, calcule e mostre a quantidade de palavras da frase digitada. 
SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, pegando caractere por caractere. 
Comparar cada caractere com espaço em branco. 
Quando encontrar um espaço, acrescentar um na quantidade. 


Como após a última palavra não tem espaço, acrescentar um na quantidade. 


PASCAL SOLUÇÃO: 
cD \EXERC\CAP9\PASCAL\EX3.PAS e \EXERC\CAP9\PASCAL\EX3.EXE 


C/c++ ENNIO 
D \EXERC\CAP9\C++\EX3.CPP e \EXERC\CAP9\C++\EX3.EXE 


RNA SoLução: 
(Emas EXERCÍCAP9NJAVANEX3.java e NEXERCÍCAP9NJAVANEX3.class 


J Faça um programa que receba uma frase e mostre as letras que se repetem, junto com o número de 
repetições. 


Exemplo: A PROVA FOI ADIADA 
A letra À apareceu 5 vezes. 
A letra O apareceu 2 vezes. 
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A letra I apareceu 2 vezes. 
A letra D apareceu 2 vezes. 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 
Percorrer a frase, pegando caractere por caractere. 
Verificar se é a primeira vez que esse caractere aparece na frase. 
Caso seja a primeira vez, atribuir um ao contador de aparições. 
Caso contrário, incrementar o contador de aparições em uma unidade. 


Mostrar todas as letras que apareceram mais de uma vez (que se repetiram), junto com 
o total de repetições. 


rasca SOLUÇÃO: 
NEXERCACAP9NPASCALVEX4.PAS e NEXERCICAP9NPASCALNEX4.EXE 


peidar SOLUÇÃO: 
\EXERC\CAP9\C++\EX4.CPP e \EXERC\CAP9\C++\EX4. EXE 


BESA- SoLução: 
D \EXERC\CAP9\JAVA\EX4.java e \EXERC\CAP9\JAVA\EX4.class 


EA Faça um programa para criptografar uma frase dada pelo usuário (a criptografia troca as vogais da 
frase por *). 
Exemplo: 
Frase: o ESTOU NA ESCOLA 
Saída: ** * ST** NE *SC*L* 
SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, comparando cada caractere com as vogais. 


Quando encontrar uma vogal, substituí-la por um asterisco. 


reca SOLUÇÃO: 
NEXERCACAP9NPASCALVEX5.PAS e NEXERCICAP9NPASCALNEX5. EXE 


eylen Ra SoLução: 
Eds \EXERC\CAP9\C++\EX5.CPP e \EXERC\CAP9\C++\EX5. EXE 


BAIA SoLução 
ERES VEXERCICAP9NJAVANEX5. java e VEXERCACAP9NJAVANEX5.class 


EA Faça um programa que receba duas frases e gere uma terceira que represente a combinação das pala- 
vras das duas frases recebidas. 


Exemplo: 

Frase 1: Hoje está um belo dia 

Frase 2: Talvez chova amanhã 

Saída: Hoje talvez está chova um amanhã belo dia 


SoLUÇÃO: 
Digitar duas frases. 


Pegar o tamanho das frases digitadas. 


Percorrer a primeira frase, pegando caractere por caractere, até chegar a um espaço 
em branco ou ao fim da frase. 
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Quando encontrar o espaço em branco ou o fim da primeira frase, foi obtida uma pa- 


lavra completa. Concatená-la à nova frase. 


Percorrer a segunda frase, pegando caractere por caractere, até chegar a um espaço 


em branco ou ao fim da frase. 


Quando encontrar o espaço em branco ou o fim da segunda frase, foi obtida uma palavra 


completa. Concatená-la à nova frase. 


Repetir os procedimentos anteriores, percorrendo as duas frases digitadas até o fi- 


nal. 


PASCAL SOLUÇÃO: 
cm \EXERC\CAP9\PASCAL\EX6.PAS e \EXERC\CAP9\PASCAL\EX6 . EXE 


C/C++ SoLução: 
D \EXERC\CAP9\C++\EX6.CPP e \EXERC\CAP9\C++\EX6.EXE 


E-Go- SoLução: 
D \EXERC\CAP9\JAVA\EX6.java e \EXERC\CAP9\JAVA\EX6.class 


IEA Faça um programa que receba uma frase e coloque as palavras da frase em ordem alfabética. 
Exemplo: 
Entrada: À informática está em constante evolução 
Saída: A constante em está evolução informática 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 


Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 


completa. 


Se a nova frase (onde as palavras ficarão em ordem alfabética) estiver vazia, copiar 


nela a palavra obtida. 


Caso contrário, percorrer a nova frase até encontrar a posição adequada para colocar 


a palavra extraída da frase digitada. 


Caso a palavra extraída da frase digitada seja alfabeticamente maior que todas as 
palavras que já estão armazenadas na nova frase, concatenar essa palavra ao final 


da nova frase. 


PASCAL [RSioRioito 
css NEXERCACAP9NPASCALVEX7.PAS e NEXERCICAP9NPASCALNEX7. EXE 


VLET SoLução: 
\EXERC\CAP9\C++\EX7.CPP e NEXERCICAP9NC++NEX7. EXE 


PE] 
E-G- SoLução: 
a \EXERC\CAP9\JAVA\EX7.java e \EXERC\CAP9\JAVA\EX7.class 


EJ Faça um programa que receba uma frase, calcule e mostre a quantidade de vezes que a palavra AULA 


aparece na frase digitada. 
SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 


Percorrer a frase, pegando caractere por caractere. 
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Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 
completa. 


Se a palavra completa for igual à cadeia AULA, acrescentar um no contador. 


PASCAI, SoLUÇÃO: 
D \EXERC\CAP9\PASCAL\EX8.PAS e \EXERC\CAP9\PASCAL\EX8.EXE 


Lena SoLução: 
C \EXERC\CAP9\C++\EX8.CPP e \EXERC\CAP9\C++\EX8. EXE 


RB WIAN SoLução: 
D \EXERC\CAP9\JAVA\EX8.java e \EXERC\CAP9\JAVA\EX8.class 


REA Faça um programa que receba uma frase e uma palavra, calcule e mostre a quantidade de vezes que a 
palavra digitada aparece na frase. 


Exemplo: 
Frase: EU ESTOU NA ESCOLA E A ESCOLA É LEGAL. 


Palavra: ESCOLA 
Resposta: A palavra ESCOLA apareceu 2 vezes na frase. 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 
Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 
completa. 


Se a palavra completa for igual à palavra digitada, acrescentar um no contador. 
INSON SOLUÇÃO: 
\EXERC\CAP9\PASCAL\EX9.PAS e \EXERC\CAP9\PASCAL\EX9.EXE 
C/c++ Solução: 
\EXERC\CAP9\C++\EX9.CPP e \EXERC\CAP9\C++\EX9.EXE 


SEGS SoLução: 
\EXERC\CAP9\JAVA\EX9.java e \EXERC\CAP9\JAVA\EX9.class 


ELN Faça um programa que receba uma frase e troque a palavra ALUNO por ESTUDANTE e a palavra 
ESCOLA por UNIVERSIDADE. 


Exemplo: EU SOU ALUNO DA ESCOLA 
Saída: EU SOU ESTUDANTE DA UNIVERSIDADE 
SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 
Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 
completa. 


Se a palavra completa for igual à cadeia ALUNO, esta deverá ser removida da frase 
digitada e no seu lugar deverá ser inserida a cadeia ESTUDANTE. 


Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 
completa. 
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Se a palavra completa for igual à cadeia ESCOLA, esta deverá ser removida da frase 
digitada e no seu lugar deverá ser inserida a cadeia UNIVERSIDADE. 


JASON SOLUÇÃO: 

D \EXERC\CAP9\PASCAL\EX10.PAS e \EXERC\CAP9\PASCAL\EX10.EXE 
C/c++ SoLução: 

D \EXERC\CAP9\C++\EX10.CPP e \EXERC\CAP9\C++\EX10.EXE 


E-A- SoLução: 
D \EXERC\CAP9\JAVA\EX10.java e \EXERC\CAP9\JAVA\EX10.class 


EIR Faça um programa que receba uma frase e, a cada ocorrência da palavra TECLADO, insira o texto 
OU MOUSE. 


Exemplo: 


Frase: PODE-SE UTILIZAR O TECLADO PARA ENTRADA DE DADOS. 
Resposta: PODE-SE UTILIZAR O TECLADO OU MOUSE PARA ENTRADA DE DADOS. 


SoLuçÃo: 


Digitar uma frase. 
Pegar o tamanho da frase digitada. 
Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 
completa. 


Se a palavra completa for igual à cadeia TECLADO, deverá ser inserida (concatenada) 
após sua ocorrência a cadeia OU MOUSE. 


PASCAL SoLUÇÃO: 

E VEXERCICAP9NPASCALNEX11.PAS e NEXERCICAP9NPASCALNEX11.EXE 
VETA Solução: 

C- \EXERC\CAP9\C++\EX11.CPP e \EXERC\CAP9\C++\EX11.EXE 


RANMA SoLução: 
RES \EXERC\CAP9\JAVA\EX11.java e \EXERC\CAP9\JAVA\EX11.class 


EPA Faça um programa para criptografar uma frase dada pelo usuário, ou seja, a criptografia deverá in- 
verter a frase. 


Exemplo: 
Frase: EU ESTOU NA ESCOLA 
Saída: ALOCSE AN UOTSE UE 


SoLUçÃo: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 


Percorrer a frase do último caractere ao primeiro, copiando-o para a nova cadeia. 


PASCAL SOLUÇÃO: 
E VEXERCACAP9NPASCALNEX12.PAS e NEXERCICAP9NPASCALNEX12.EXE 


c/c++ Solução: 
D \EXERC\CAP9\C++\EX12.CPP e \EXERC\CAP9\C++\EX12.EXE 
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RANMA SoLução: 
EEE \EXERC\CAP9\JAVA\EX12.java e NEXERCICAP9NJAVANEX12.class 


EEA Faça um programa para criptografar uma frase dada pelo usuário, ou seja, a criptografia deverá inver- 
ter cada palavra da frase. 


Exemplo: 


Frase: EU ESTOU NA ESCOLA 
Saída: UE UOTSE AN ALOCSE 


SOLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 
Percorrer a frase, pegando caractere por caractere. 
Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma palavra 
completa. 
Pegar o tamanho da palavra completa. 
Percorrer a palavra completa do último caractere ao primeiro, copiando-o para a nova 
palavra. 
Concatenar a nova palavra completa na nova frase. 


PASCAL SOLUÇÃO: 
NEXERCACAP9NPASCALVEX13.PAS e NEXERCACAP9NPASCALNEX13.EXE 


EE 
C/c++ ENIO: 
GEE \EXERC\CAP9\C++\EX13.CPP e \EXERC\CAP9\C++\EX13.EXE 


RB WIAN SoLução: 
D \EXERC\CAP9\JAVA\EX13.java e \EXERC\CAP9\JAVA\EX13.class 


ELA Faça um programa que receba uma frase com letras minúsculas e converta a primeira letra de cada 
palavra da frase para maiúscula. 
Exemplo: 
Entrada: fazer exercícios faz bem. 


Saída: Fazer Exercícios Faz Bem. 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase digitada. 
Converter o primeiro caractere da frase para maiúsculo. 
Percorrer a frase, pegando caractere por caractere. 
Cada vez que encontrar um espaço em branco, converter o próximo caractere para mai- 


úsculo. 


PASCAL SOLUÇÃO: 

css VEXERCICAP9NPASCALVEX14.PAS e NEXERCICAP9NPASCALNEX14.EXE 
C/c++ ENIO 

Ea \EXERC\CAP9\C++\EX14.CPP e \EXERC\CAP9\C++\EX14.EXE 


DEGE SoLução: 
G \EXERC\CAP9\JAVA\EX14.java e \EXERC\CAP9\JAVA\EX14.class 


EA Faça um programa que receba um nome e gere como saída o nome digitado e seu login. Lembre-se 
de respeitar as letras minúsculas e maiúsculas, já que o login será sempre com letras minúsculas. A 
regra para geração do login é: a primeira letra do nome e, caso exista apenas um sobrenome, deve-se 
acrescentá-lo; caso existam dois sobrenomes, deve-se gerar a primeira letra do nome, mais a primeira 
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letra do primeiro sobrenome, seguido do último sobrenome; caso existam três ou mais sobrenomes, 
deve-se proceder como na situação anterior, considerando o nome, o primeiro sobrenome e o último 
sobrenome. 


Exemplos: 


Nome: Pedro Hansdorf 
Login: phansdorf 


Nome: Robson Soares Silva 
Login: rssilva 


Nome: Jaqueline Oliveira Fernandes Espanhola 
Login: joespanhola 


SoLUÇÃO: 
Digitar um nome. 
Converter todas as letras do nome digitado para minúsculas. 
Inicializar o login (nova cadeia) com a primeira letra do primeiro nome. 


Verificar se o nome digitado tem apenas um espaço em branco. Caso tenha, concatenar (jun- 
tar) ao login os caracteres da posição posterior ao espaço até o fim do nome digitado. 


Se o nome tiver mais de um espaço em branco, procurar o primeiro espaço e concatenar 
(juntar) ao login o caractere da posição posterior à posição do espaço; procurar o 
último espaço e concatenar (juntar) ao login os caracteres da posição posterior a 
esse último espaço até o fim do nome digitado. 


PASCAL SOLUÇÃO: 
VEXERCACAP9NPASCALVEX15.PAS e NEXERCACAP9NPASCALNEX15.EXE 


C/c++ EI 
D \EXERC\CAP9\C++\EX15.CPP e \EXERC\CAP9\C++\EX15.EXE 


RANMA SoLução: 
\EXERC\CAP9\JAVA\EX15.java e \EXERC\CAP9\JAVA\EX15.class 


HJ Faça um programa que receba uma palavra e verifique se ela constitui um palíndromo, ou seja, se a 
palavra escrita do fim para o começo fica igual à palavra escrita do começo para o fim. 


Exemplos: 

ARARA 

ANA 

MIRIM 

SoLUÇÃO: 
Digitar uma palavra. 
Gerar uma nova palavra, que será a palavra digitada invertida. 
Comparar a palavra digitada com a palavra invertida. 


Se as palavras forem iguais, trata-se de palíndromo; caso contrário, não se trata 
de palíndromo. 


PASCAL SOLUÇÃO: 
D \EXERC\CAP9\PASCAL\EX16.PAS e \EXERC\CAP9\PASCAL\EX16.EXE 


C/C++ EO 
i \EXERC\CAP9\C++\EX16.CPP e \EXERC\CAP9\C++\EX16.EXE 


RB LWIA NA SoLução: 
GE \EXERC\CAP9\JAVA\EX16.java e NEXERCICAP9NJAVAlEX16.class 
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EFA Faça um programa que receba uma frase e uma palavra. Caso a frase contenha a palavra ESCOLA, 
deverá substituí-la pela palavra digitada. 


Exemplo: 


Frase: EU MORO PERTO DE UMA ESCOLA. MAS ESSA ESCOLA NÃO É A MELHOR. 
Palavra: PADARIA 


Resposta: EU MORO PERTO DE UMA PADARIA. MAS ESSA PADARIA NÃO É A MELHOR. 


SOLUÇÃO: 
Digitar uma frase. 
Digitar a palavra que substituirá a palavra ESCOLA. 
Converter a palavra e a frase digitadas para letras maiúsculas. 
Pegar o tamanho da frase. 
Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma nova 
palavra. 


Comparar a nova palavra com a palavra ESCOLA. 


Quando encontrar a palavra ESCOLA, apagá-la e no seu lugar inserir a palavra digi- 
tada. 


Depois de substituir, atualizar o tamanho da frase a ser percorrida. 


rasca SOLUÇÃO: 
VEXERCICAP9NPASCALVEX17.PAS e NEXERCICAP9NPASCALNEX17.EXE 


pela SOLUÇÃO: 
\EXERC\CAP9\C++\EX17.CPP e \EXERC\CAP9\C++\EX17.EXE 


JAVA SoLução: 
D \EXERC\CAP9\JAVA\EX17.java e \EXERC\CAP9\JAVA\EX17.class 


EEJ Faça um programa que se comporte como vírus, ou seja, que duplique cada uma das palavras digitadas 
pelo usuário. 


Exemplo: 


Frase: EU ESTOU NA ESCOLA 
Saída: EU EU ESTOU ESTOU NA NA ESCOLA ESCOLA 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, pegando caractere por caractere. 
Comparar cada caractere com espaço em branco. 


Quando encontrar espaço ou o fim da frase, foi encontrado o fim de uma palavra. Co- 
piar a palavra encontrada. 


Inserir a palavra encontrada na frase duas vezes. 


est SOLUÇÃO: 
VEXERCACAP9NPASCALVEX18.PAS e NEXERCACAP9PASCALNEX18.EXE 


eyler Ra SoLução: 
GEE \EXERC\CAP9\C++\EX18.CPP e \EXERC\CAP9\C++\EX18.EXE 


RB WIAN SoLução: 
GEES \EXERC\CAP9\JAVA\EX18.java e \EXERC\CAP9\JAVA\EX18.class 
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BEAR Faça um programa que receba uma frase. Caso na frase apareça o nome de um mês do ano por exten- 
so, deverá substituí-lo pelo seu número correspondente, como no exemplo. 


Exemplo: 
Frase: NO MÊS DE JANEIRO FAZ CALOR. 
Nova frase: NO MÊS 01 FAZ CALOR. 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, pegando caractere por caractere. 


Cada vez que encontrar um espaço em branco ou o fim da frase, foi obtida uma nova 
palavra. 


Comparar a nova palavra com o nome dos meses do ano. Se houver coincidência, substi- 
tuir o nome do mês pelo seu número correspondente. 


Depois de substituir, atualizar o tamanho da frase a ser percorrida. 
PASCAL SOLUÇÃO: 
D \EXERC\CAP9\PASCAL\EX19.PAS e NEXERCICAP9NPASCALNEX19.EXE 


C/c++ ENNIO 
D \EXERC\CAP9\C++\EX19.CPP e \EXERC\CAP9\C++\EX19.EXE 


BAIANA SoLução: 
CE \EXERC\CAP9\JAVA\EX19.java e \EXERC\CAP9\JAVA\EX19.class 


EIA Faça um programa que receba o nome completo de uma pessoa e mostre os nomes intermediários entre 
o primeiro nome e o último sobrenome abreviados. 


Exemplo: 


Nome: Maria Silva Costa 
Saída: Maria S. Costa 


Nome: João Carlos Gomes Marques 
Saída: João C. G. Marques 


SoLuçãÃo: 


Digitar um nome. 

Pegar o tamanho do nome. 

Percorrer o nome, pegando caractere por caractere. 

Comparar cada caractere com espaço em branco. 

Quando encontrar o primeiro espaço em branco, foi encontrado o fim do primeiro nome. 
Copiar a palavra obtida, pois o primeiro nome não será abreviado. 

Percorrer a cadeia, pegando caractere por caractere, do final para o começo. 


Comparar cada caractere com espaço em branco, para achar a posição inicial do último 
nome, pois este também não será abreviado. 


Percorrer a cadeia do final do primeiro nome até a posição inicial do último nome. 


Após encontrar um espaço, pegar o caractere seguinte, juntar ao novo nome e acres- 
centar um ponto e um espaço. 


Juntar a primeira palavra com as abreviaturas e depois com a última palavra. 
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PASCAI, SoLUÇÃO: 
D \EXERC\CAP9\PASCAL\EX20.PAS e \EXERC\CAP9\PASCAL\EX20.EXE 


eyler Ra SoLuçãÃo: 
\EXERC\CAP9\C++\EX20.CPP e \EXERC\CAP9\C++\EX20.EXE 


E 
RB WIAN SoLução: 
fia \EXERC\CAP9\JAVA\EX20.java e \EXERC\CAP9\JAVA\EX20.class 


FAH Faça um programa que receba o nome completo de uma pessoa e reescreva-o de acordo com o exemplo 
a seguir. 


Exemplo: 


Nome: Maria Silva Costa 
Saída: Costa, M. S. 


Nome: João Carlos Gomes Marques 
Saída: Marques, J. C. G. 


SOLUÇÃO: 


Digitar um nome. 
Pegar o tamanho do nome. 


Percorrer o nome, pegando caractere por caractere, do final da frase para o começo 
dela. 


Comparar cada caractere com espaço em branco. 


Quando encontrar o primeiro espaço em branco, foi encontrado o começo do último nome. 
Copiar o último nome, pois este deverá ser o primeiro. 


Juntar ao novo nome uma vírgula e um espaço em branco. 


Juntar ao novo nome a primeira letra do nome digitado com um ponto e um espaço em 
branco. 


Percorrer a frase, pegando caractere por caractere, do início do nome até a posição 
inicial da última palavra. 


Comparar cada caractere com espaço em branco e, quando encontrar, juntar ao novo 
nome a letra da próxima posição, com um ponto e um espaço em branco. 


PASCAI, SoLUÇÃO: 
CE \EXERC\CAP9\PASCAL\EX21.PAS e \EXERC\CAP9\PASCAL\EX21.EXE 


C/c++ Solução: 
E \EXERC\CAP9\C++\EX21.CPP e \EXERC\CAP9\C++\EX21.EXE 


VEA SOLUÇÃO: 
GSE \EXERC\CAP9\JAVA\EX21.java e \EXERC\CAP9\JAVA\EX21.class 


EYA Faça um programa que receba um nome e gere um login e uma senha. O login deverá ser composto 
pela primeira letra de cada nome em letras maiúsculas e as mesmas letras minúsculas; a senha será 
composta pela representação ASCII de cada letra do login. 


Exemplo: 


Nome: Ana Beatriz Costa 
Login: ABCabc 
Senha: 656667979899 


SoLUÇÃO: 
Digitar um nome. 


Pegar o tamanho do nome. 
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Colocar no login a primeira letra do primeiro nome em maiúsculo. 


Percorrer todo o nome, caractere por caractere, e cada vez que encontrar um espaço em 
branco, acrescentar ao login, em letra maiúscula, o caractere da posição seguinte. 


Fazer uma cópia do login atual, converter os caracteres da cópia para letras minús- 
culas e concatenar (juntar) ao login. 
Percorrer todas as posições do login gerado e compor a senha, convertendo cada ca- 


ractere encontrado para a sua representação na tabela ASCII. 


PASCAL SOLUÇÃO: 
E! VEXERCACAP9NPASCALVEX22.PAS e NEXERCACAP9NPASCALNEX22.EXE 


LETT SoLução: 
Es \EXERC\CAP9\C++\EX22.CPP e NEXERCACAP9NC++NVEX22. EXE 


JAVA SoLução: 
uso \EXERC\CAP9\JAVA\EX22.java e NEXERCICAP9NJAVANEX22.class 


PER Faça um programa para criptografar uma frase em que cada caractere deverá ser substituído pelo ca- 
ractere que está três posições à sua frente na tabela ascII. Os três últimos caracteres da tabela ASCII 
deverão ser substituídos pelos três primeiros. 


Exemplo: 


BONECO ZABUMBA 
ERQHFR CDEXPED 


SoLuçÃo: 
Digitar uma frase. 
Pegar o tamanho da frase. 


Percorrer toda a frase, convertendo cada caractere para ASCII, acrescentando três e 
convertendo novamente para caractere. 


Copiar o novo caractere para a frase criptografada. 


PASCAL [RSioRtoito 
C \EXERC\CAP9\PASCAL\EX23.PAS e \EXERC\CAP9\PASCAL\EX23.EXE 


VETIA Solução: 
E \EXERC\CAP9\C++\EX23.CPP e \EXERC\CAP9\C++\EX23.EXE 


JAVA SoLuçÃo: 
c \EXERC\CAP9\JAVA\EX23.java e \EXERC\CAP9\JAVA\EX23.class 


ELA Faça um programa que receba um verbo regular terminado em AR e mostre sua conjugação no pre- 
sente. 


Exemplo: 

Verbo: andar 

Eu ando 

Tu andas 

Ele anda 

Ela anda 

Nós andamos 

Vós andaisEles andam 
Elas andam 
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SoLUÇÃO: 
Digitar um verbo terminado em AR. 
Pegar o tamanho do verbo. 
Gerar uma palavra que será o verbo digitado com os dois últimos caracteres excluídos. 


Mostrar o conjugação acrescentando o, as, a, amos, ais e am à palavra gerada. 


PASCAL SOLUÇÃO: 
VEXERCICAP9NPASCALVEX24.PAS e NEXERCICAP9NPASCALNEX24.EXE 


GE 
oPAeR Ra SoLução: 
C \EXERC\CAP9\C++\EX24.CPP e \EXERC\CAP9\C++\EX24.EXE 


KE-W SOLUÇÃO: 
D \EXERC\CAP9\JAVA\EX24.java e \EXERC\CAP9\JAVA\EX24.class 


FER Faça um programa que receba uma frase e conte quantos verbos existem nela, considerando que os 
verbos terminam em R. 


SoLUÇÃO: 
Digitar uma frase. 
Pegar o tamanho da frase. 
Percorrer a frase, analisando caractere por caractere. 
Quando encontrar um espaço ou o final da frase, analisar o caractere anterior e, se 


este for a letra R, acrescentar um no contador. 


TANTO NH SOLUÇÃO: 
NEXERCACAP9NPASCALVEX25.PAS e NEXERCACAP9NPASCALNEX25.EXE 


CVETA SoLução: 
\EXERC\CAP9\C++\EX25.CPP e NEXERCICAP9NC++NEX25. EXE 


RANMA SoLução: 
VEXERCICAP9NJAVANEX25. java e \EXERC\CAP9\JAVA\EX25.class 


EXERCÍCIOS PROPOSTOS 


BEER Faça um programa para criptografar uma frase dada pelo usuário. Na criptografia, a frase deverá ser invertida 
e as consoantes deverão ser trocadas por *. 


Exemplo: 


Frase: EU ESTOU NA ESCOLA 
Saída: AFOHHE A# UOHHE UE 


IFA Faça um programa que receba uma frase e mostre cada palavra dela em uma linha separada. 


Exemplo: 


Frase: COMPUTADORES SÃO MÁQUINAS POTENTES 
Saída: 

COMPUTADORES 

SÃO 

MÁQUINAS 

POTENTES 


IEJ Faça um programa que receba uma frase e gere uma nova, retirando os espaços excedentes no início e no fim 
da frase e entre suas palavras. 
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EA Faça um programa que receba uma frase, calcule e mostre a quantidade de palavras da frase digitada. Antes 
de contar a quantidade de palavras da frase, esta deverá passar pelas seguintes correções: 
a) Eliminação de espaços no início da frase. 
b) Eliminação de espaços no fim da frase. 
c) Eliminação de espaços duplicados entre palavras. 

EA Faça um programa que receba duas cadeias de caracteres e verifique se a primeira cadeia digitada é permuta- 
ção da segunda cadeia, ou seja, se todos os caracteres da primeira cadeia estão presentes na segunda cadeia, 
mesmo que em posições diferentes. 


Exemplo: 
“abecde” é uma permutação de “cbadce”, mas não é de “abcdef” nem de “abcde” 

WA Faça um programa que receba uma frase e gere uma nova frase, duplicando cada caractere da frase digitada. 
Exemplo: 


Frase: PROGRAMAR É BOM 
Saída: PPRROOGGRRAAMMAARR ÉÉ BBOOMM 


IEA Faça um programa que receba uma frase e mostre quantas letras diferentes ela contém. 


REA Faça um programa que receba uma frase e um caractere e verifique se o caractere digitado é encontrado na 
frase ou não e, se for encontrado, quantas vezes isso acontece. 


BEAR Faça um programa que receba uma frase e um caractere e verifique em que posição da frase o caractere digi- 
tado aparece pela primeira vez. 

ELA Faça um programa que receba uma frase e um caractere e verifique em que posição da frase o caractere 
digitado aparece pela última vez. 

ELE Faça um programa que receba uma frase e mostre quantas vezes cada palavra aparece na frase digitada. 


EPA Faça um programa que receba uma data no formato DD/MM/AAAA e a mostre com o mês por extenso: 
DD/mês por extenso/AAA A 


EEA Faça um programa que receba uma cadeia de caracteres e o número de repetições (limitado a 5) e gere uma 
nova cadeia. 


Exemplo: 


Cadeia = Ui! 
Número = 3 
Nova cadeia = Ui! Ui! Ui! 


ELA Faça um programa que receba uma frase e converta as vogais de suas palavras para maiúsculo e as con- 
soantes para minúsculo. 


HA Faça um programa que receba uma frase e, cada vez que aparecer nela um algarismo entre O e 9, substi- 
tua-o, escrevendo-o por extenso. 
Exemplo: 


Frase: EU ESTOU NA POLTRONA 5. 
Saída: EU ESTOU NA POLTRONA CINCO. 


HJ Faça um programa que receba uma frase e mostre quantas letras, quantos números e quantos espaços 
existem nela. 


EFA Faça um programa que receba uma frase e, a cada duas palavras dela, realize uma criptografia, ou seja: 
a primeira letra da primeira palavra da frase concatenada com a última letra da segunda palavra, conca- 
tenada com a segunda letra da primeira palavra e com a penúltima letra da segunda palavra e assim por 
diante. No caso de quantidade de palavras ímpares, a última palavra deve simplesmente ser invertida. 
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Exemplos: 


Frase: Aula com bola 
Saída: Amuolca alob 


Frase: Casa com janelas coloridas 
Saída: Cmaosca jsaandeilraosloc 


EEA Faça um programa que criptografe cada palavra de uma frase, substituindo por ? a última metade de 
seus caracteres. 
Exemplo: 


A aula é boa mas poderia ser mais curta. 
? au??? b?? m?? pod???? s?? ma?? cu???. 

EL] Faça um programa que receba uma frase e faça a criptografia dela, substituindo as vogais pelos seguintes 
números:a=1,e=2,1=3,0=4eu=ó5. 

EIA Faça um programa que receba uma frase e faça a criptografia dela, utilizando a representação ASCII de 
cada caractere mais um espaço, e depois proceda à sua descriptografia. 

PIE Faça um programa que receba uma frase e realize a criptografia dela, trocando a primeira e a última 
palavra de lugar. 


Exemplo: 


Frase: ESTRELAS E LUA ESTÃO NO CÉU 
Saída: CÉU E LUA ESTÃO NO ESTRELAS 


EFA Considere uma string composta por várias subsequências, por exemplo, cccaaaabbbbxdddddddddaaannn. 
A menor subsequência é a da letra x, com apenas um elemento; a maior subsegquência é a da letra d, 
com nove elementos. Faça um programa para ler uma string e mostrar qual é a letra que ocorre na 
maior subsequência e o tamanho dessa subsequência. 


Exemplo: 


Entrada: aaabbbbaaa 
Saída: maior b, tamanho 4 


FR A busca por subcadeias dentro de grandes cadeias de caracteres é um problema clássico na computação, 
especificamente em bancos de dados. Faça um programa que receba uma cadeia de caracteres e uma 
subcadeia, determine e mostre quantas vezes a subcadeia aparece dentro da cadeia. 


see Observação 


O tamanho da subcadeia obrigatoriamente deve ser menor que o da cadeia. 
Exemplos: 


Entradas: 

Cadeia = aaaassdffffghssiiii 

Subcadeia = ss 

Saída: a subcadeia aparece 2 vez(es) na cadeia 


Entradas: 

Cadeia = xxxxxaauuuyyyydrtsss 

Subcadeia = yydrts 

Saída: a subcadeia aparece 1 vez(es) na cadeia. 
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Entradas: 
Cadeia = fffffhuioj))jkkkkkssjh 


Erro! Tamanho incorreto. Digite outra subcadeia. 
Subcadeia = dsh 
Saída: a subcadeia não está contida na cadeia. 


EZH Faça um programa que receba um verbo regular terminado em ER e mostre sua conjugação no presente. 
Exemplo: 


verbo: vender 
Eu vendo 

Tu vendes 

Ele vende 

Ela vende 

Nós vendemos 
Vós vendeis 
Eles vendem 
Elas vendem 


FER Faça um programa que receba uma frase e faça a criptografia, retirando das palavras suas vogais. O 
programa deverá armazenar essas vogais e suas posições originais em vetores, mostrar a frase cripto- 
grafada e posteriormente descriptografá-la. 


CAPÍTULO 


10.1 Definição de registros 


Em todos os capítulos anteriores, as variáveis utilizadas nos programas conseguem armazenar apenas 
um tipo de dado, definido no momento em que foram declaradas. Além de facilitar o uso das estruturas de 
controle de um programa, as variáveis servem, também, para representar entidades identificadas no proble- 
ma real que será resolvido computacionalmente. 

Nesses casos, é bastante comum a necessidade de armazenar, dentro de uma mesma variável, diferentes 
tipos de dados. É aí que entram em cena os registros. 

Registros conseguem agregar vários dados acerca de uma mesma entidade. Com isso, os programado- 
res podem gerar novos tipos de dados, não se limitando apenas à utilização dos tipos de dados primitivos 
fornecidos pelas linguagens de programação. 

Cada dado contido em um registro é chamado campo. Os campos podem ser de diferentes tipos pri- 
mitivos ou, ainda, podem representar outros registros. É por essa razão que os registros são conhecidos, 
também, como variáveis compostas heterogêneas. 


10.2 Declaração de registros em algoritmos 


A declaração de uma variável registro é o primeiro passo para a sua utilização. Isso significa especificar 
o nome de seus campos com seus respectivos tipos. 

Como acontece com qualquer outro tipo de dado, uma variável registro pode ser simples, um vetor ou 
uma matriz. À sintaxe correta para a declaração de uma variável registro é mostrada a seguir. 


DECLARE nome da variável registro REGISTRO (nome campol TIPO DO CAMPOL, 
nome campo2 TIPO DO CAMPO2, ..., nome campoN TIPO DO CAMPOn) 


Exemplo 1: 
DECLARE conta REGISTRO (num, saldo NUMÉRICO, nome LITERAL) 


No exemplo 1, foi declarada uma variável chamada conta. Essa variável é um registro composto por 
três campos: num e saldo, capazes de armazenar valores numéricos, e nome, capaz de armazenar um valor 
literal. A seguir, é mostrada uma representação gráfica da variável conta. 


num 
Variável conta saldo 


nome 
Exemplo 2: 
DECLARE conta[3] REGISTRO (num, saldo NUMÉRICO, nome LITERAL) 


No exemplo 2, foi declarada uma variável chamada conta. Essa variável é um vetor de três posições 
(de 1 a 3). Em cada posição será armazenado um registro, composto por três campos: num e saldo, capazes 
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de armazenar valores numéricos, e nome, capaz de armazenar um valor literal. A seguir, é mostrada uma 
representação gráfica do vetor conta. 


1 2 3 

num num num 
Veror onta saldo saldo saldo 

nome nome nome 


10.2.1 Acesso aos campos de um registro em algoritmo 


O uso de um registro é possível pelo acesso individual a seus campos, quer seja para gravar quer seja para 
recuperar um dado. O acesso a determinado campo de registro é feito informando-se o nome da variável, 
seguido por um ponto e pelo nome do campo desejado. A seguir, é mostrada a forma geral a ser utilizada. 


nome da variável do tipo registro.nome do campo 


À seguir, serão apresentados alguns trechos de algoritmos, exemplificando o uso de registros (a nume- 


ração das linhas serve apenas para auxiliar a explicação). 


Exemplo 1: 


Io DECLARE conta REGISTRO (numero, saldo NUMÉRICO, titular LITERAL) 
2. ESCREVA “Digite o número da conta: “” 

3. LEIA conta.numero 

4. ESCREVA “Digite o nome do titular da conta: “ 

5. LEIA conta.titular 

6. ESCREVA “Digite o saldo da conta: “ 

7. LEIA conta.saldo 


No exemplo 1, observa-se a criação de uma variável registro chamada conta (linha 1). Na declaração, 
foi definido que conta possuirá 3 campos: numero e saldo, que poderão armazenar valores numéricos, e 
titular, que poderá armazenar valores literais. Nas linhas 3, 5 e 7, o camando LEIA permite que sejam 
atribuídos valores aos campos numero, titular e saldo. Observe que, nessas três linhas, os campos só pu- 


deram ser acessados porque foram precedidos pelo nome da variável conta. 


Exemplo 2: 


1. DECLARE funcionario[4] REGISTRO (nome LITERAL, salario NUMÉRICO) 
Do i NUMÉRICO 

3. PARA i + 1 ATÉ 4 FAÇA 

lo INÍCIO 

o ESCREVA “Digite o nome do funcionário “, i, “2: ! 

6. LEIA funcionario[i].numero 

To ESCREVA “Digite o salário do funcionário “, i, “2! 

8. LEIA funcionario[i].salario 

9. FIM 


O exemplo 2 apresenta a criação e o uso de um vetor de quatro posições. Cada posição tem capacidade 
para armazenar os campos nome e salario, definidos no registro. Assim como acontece com qualquer vetor, 
as posições devem ser acessadas com o uso de um índice. No exemplo 2, esse índice é a variável i, contro- 
lada pelo PARA, que permite sua variação de 1 até 4 (o tamanho do vetor). 

Após a execução de todas as iterações do PARA, o vetor estará completamente preenchido. A seguir, 
mostramos uma ilustração de como o vetor funcionario ficaria. 


Vetor 


funcionario 


1 2 3 4 
nome João nome Maria nome Pedro nome Lúcia 
salario 1000,00 salario 5000,00 salario 1800,00 salario 2700,00 
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Exemplo 3: 

1. PARA i < 1 ATÉ 4 FAÇA 

Pa INÍCIO 

Bio ESCREVA “Funcionário que ocupa a posição “, i, “ no vetor: “ 
4. ESCREVA “Nome: “, funcionario[i].nome 

Do ESCREVA “Salário: “, funcionario[i].salario 

6. FIM 


O exemplo 3 faz uso de um vetor de quatro posições, chamado funcionario. À estrutura de repetição 
PARA, iniciada na linha 1, permite que as quatro posições do vetor sejam percorridas e os dados encontrados 
sejam mostrados. A seguir, pode-se ver uma simulação da execução desse pedaço de algoritmo, consideran- 
do que o vetor tenha sido preenchido como ilustrado no exemplo 2. 


Memória Tela 


Funcionário que ocupa a posição 1 no vetor: 
1 ome: João 
Salário: 1000,00 
Funcionário que ocupa a posição 2 no vetor: 
2 ome: Maria 
Salário: 5000,00 
Funcionário que ocupa a posição 3 no vetor: 
3 ome: Pedro 
Salário: 1800,00 
Funcionário que ocupa a posição 4 no vetor: 


4 ome: Lúcia 
Salário: 2700,00 


10.3 Declaração de registros em PASCAL 


Em PASCAL, a utilização de registros requer dois passos: a definição da estrutura do registro, em que 
se utilizam as palavras reservadas TYPE € RECORD, e a declaração da variável registro, que segue a sintaxe de 
declaração de qualquer variável. 


TYPE nome da variável registro = RECORD 
campol:tipol; 
campo2:tipo2; 
campoN:tipoN; 
END; 

VAR nome da variável: nome da variável registro; 


Exemplo 1: 

TYPE REGISTRO = RECORD 
num : INTEGER; 
nome : STRING[35]; 
saldo : REAL; 
END; 


VAR conta: REGISTRO; 
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No exemplo 1, um registro chamado REGISTRO foi definido. Isso significa que o programa poderá utili- 
zar um novo tipo de dado. Depois disso, a variável conta foi declarada como um tipo REGISTRO. Portanto, 
conta terá espaço para armazenar num, nome € saldo. 


Exemplo 2: 


TYPE EXEMPLO = RECORD 
num : INTEGER; 
nome : STRING[35]; 
saldo : REAL; END; 
VAR conta: ARRAY[1..15] OF EXEMPLO; 


No exemplo 2, um registro chamado EXEMPLO foi definido. Isso significa que o programa poderá uti- 
lizar um novo tipo de dado. Depois disso, a variável conta foi declarada como um vetor de 15 posições. 
Cada posição será um registro EXEMPLO. Portanto, cada posição do vetor conta terá espaço para armazenar 
num, nome € saldo. 


10.3.1 Acesso aos campos de um registro em PASCAL 


O uso de um registro é possível pelo acesso individual a seus campos, quer seja para gravar quer seja 
para recuperar um dado. O acesso a determinado campo de registro é feito informando-se o nome da vari- 
ável, seguido por um ponto e pelo nome do campo desejado. 

A forma geral a ser utilizada é descrita da seguinte forma: 


nome da variável do tipo registro.nome do campo 


À seguir, serão apresentados alguns trechos de programas, exemplificando o uso de registros (a nume- 
ração das linhas servem apenas para auxiliar a explicação). 


Exemplo 1: 

T TYPE BANCO = RECORD 

Zi numero: INTEGER; 

37 saldo: REAL; 

4. titular: STRING[35]; 
5. END; 

6. RE 

Ta VAR conta: BANCO; 

8. EO 


9.  WRITELN('Digite o número da conta: '); 

10. READLN(conta.numero) ; 

11. WRITELN('Digite o nome do titular da conta: '); 
12. READLN(conta.titular); 

13. WRITELN('Digite o saldo da conta: '); 

14. READLN(conta.saldo); 


No exemplo 1, pode-se ver, da linha 1 à 5, a criação de um registro, chamado Banco. Esse registro 
agrupa três tipos de dados, denominados campos do registro: o número, que é um inteiro; o saldo, que é 
um número real; e o titular, que é uma cadeia de caracteres. Na linha 7, é criada uma variável conta do 
tipo BANCO. Isso implica que os três campos do registro estão contidos nessa variável. Nas linhas 10, 12 e 
14, o camando READLN permite que sejam atribuídos valores aos campos numero, titular e saldo. Observe 
que nessas três linhas os campos só puderam ser acessados porque foram precedidos pelo nome da variável 
conta. 


Exemplo 2: 

lia asa 

2 TYPE EMPRESA = RECORD 

So nome: LITERAL; 
4. salario: REAL; 
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5. END; 

6. Edo 

7. VAR funcionarios: ARRAY [1..4] OF EMPRESA; 

8. Ro 

9. FOR i := 1 TO 4 DO 

10. BEGIN 

ibg WRITELN('Digite o nome do funcionário ’', i, ': '); 
12. READLN( funcionarios[i].nome); 

T3: WRITELN('Digite o salário do funcionário ', i, ': '); 
14. READIN (funcionarios[i].salario); 

15. END; 

Udo ovo 


O exemplo 2 apresenta a criação (linha 7) e uso de um vetor de quatro posições. Cada posição tem ca- 
pacidade para armazenar os campos nome e salario definidos no registro EMPRESA (da linha 2 à 5). Assim 
como acontece com qualquer vetor, as posições devem ser acessadas com o uso de um índice. No exemplo 
2, esse índice é a variável i, controlada pelo For, que permite sua variação de 1 até 4 (o tamanho do vetor). 

Após a execução de todas as iterações do FOR, o vetor estará completamente preenchido. A seguir, mos- 
tramos uma ilustração de como o vetor ficaria. 


1 2 3 4 
Vetor - z SS 
: À nome João nome Maria nome Pedro nome Lúcia 
funcionarios z A à z 

salario 1000,00 salario 5000,00 salario 1800,00 salario 2700,00 

Exemplo 3: 

iis a 

2. FOR i:= 1 TO 4 DO 

So BEGIN 

4. WRITELN('“Funcionário que ocupa a posição ', i, ' no vetor: '); 

Do WRITELN('Nome: ', funcionarios[i].nome); 

6. WRITELN('Salário: ', funcionarios[i].salario:6:2); 

a END; 

8. Si 


O exemplo 3 faz uso de um vetor de quatro posições, chamado funcionarios. À estrutura de repetição 
FOR, iniciada na linha 2, permite que as quatro posições do vetor sejam percorridas e os dados encontrados 
sejam mostrados. À seguir, pode-se ver uma simulação da execução desse pedaço de programa, consideran- 
do-se que o vetor tenha sido preenchido como ilustrado no exemplo 2. 


Memória Tela 


Funcionário que ocupa a posição 1 no vetor: 
1 ome: João 
Salário: 1000,00 
Funcionário que ocupa a posição 2 no vetor: 
2 ome: Maria 
Salário: 5000,00 
Funcionário que ocupa a posição 3 no vetor: 


3 ome: Pedro 
Salário: 1800,00 
Funcionário que ocupa a posição 4 no vetor: 


4 ome: Lúcia 
Salário: 2700,00 
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10.4 Declaração de registros em C/C++ 


Os registros em C/C++, chamados de estruturas, são definidos por meio da utilização da palavra reser- 
vada struct, conforme apresentado a seguir. 


struct nome da estrutura 
{ tipo campol; 
tipo campo2; 


tipo campoN; 


A partir da estrutura definida, o programa poderá considerar que existe um novo tipo de dado a ser 
utilizado chamado nome da estrutura. Esse novo tipo de dado é capaz de armazenar várias informações 
cujos tipos podem ser diferentes. Essas informações são denominadas membros da estrutura. 


Exemplo 1: 


struct ESTRUTURA 
{ int num; 
char titular[35]; 
float saldo; 


No exemplo 1, uma estrutura chamada ESTRUTURA foi definida. Isso significa que o programa poderá 
utilizar um novo tipo de dado. Variáveis declaradas que fazem uso desse tipo poderão armazenar três valo- 
res: num, titular €e saldo. 

Uma observação importante é que a struct só poderá ser utilizada dentro do bloco onde for definida. 
Por exemplo, uma struct descrita dentro das chaves que delimitam a função main só poderá ser usada por 
variáveis que também estejam dentro desse bloco. Para permitir que qualquer parte do seu programa en- 
tenda e utilize uma struct, sua definição deverá ser feita fora da função main, de preferência logo abaixo 
de todos os include. 

Para que um programa em C/C++ utilize uma struct, é necessária a declaração de variáveis desse tipo, 
da seguinte forma: 


nome da estrutura nome da variável; 


Considerando que estruturas representam novos tipos de dados, todas as operações e declarações re- 
alizadas com os tipos predefinidos da linguagem também poderão ser realizadas com as estruturas. Dessa 
maneira, além de variáveis simples, vetores e matrizes podem ser declaradas como struct. 


Exemplo 1: 


1. finclude <stdio.h> 

Pici TSE 

3. int main() 

4. 4 

Do struct EXEMPLO 

6. { int membrol; 

To char membro2[50]; 
8. 


So So 

10. EXEMPLO var; 
Milo 586 

12.5 
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No exemplo 1, pode-se ver, da linha 5 à 8, a criação de uma estrutura chamada EXEMPLO dentro da 
função main. Isso implica que todas as variáveis que precisarem ser desse tipo também deverão ser declara- 
das dentro do main. Exemplo disso é a variável var, declarada na linha 10. Como ela está fazendo uso do 
tipo EXEMPLO, possui dois valores: membrol e membro2. A seguir, mostramos uma representação gráfica da 
variável var. 


membrol 
Variável var 
membro2 
Exemplo 2: 
1. finclude <stdio.h> 
Pd RED 
3. struct BANCO 
4. { int num; 
Do char titular[35]; 
6. float saldo; 
7. }; 
8. 
9. int main() 
10.1 
Mile, aan 
12. BANCO conta; 
13 
14. } 


No exemplo 2, temos, da linha 3 à 7, um exemplo de estrutura criada fora da função main. Isso signifi- 
ca que ela poderá ser usada em qualquer parte do programa, não ficando restrita a algum bloco de chaves. 
Na linha 12, temos a declaração da variável conta, fazendo uso do tipo BANCO. Assim, conta tem três valo- 
res: num, titular e saldo. À seguir, mostramos uma representação gráfica da variável conta. 


num 


Variável conta titular 


saldo 
Exemplo 3: 
1. finclude <stdio.h> 
Po a 
3. struct BANCO 
4. { int num; 
Do char titular[35]; 
6. float saldo; 
7. }; 
8. 
9. int main() 
10.{ 
iila Ad 
12 BANCO contas[4][3]; 
3, 
14. } 


No exemplo 3, temos, da linha 3 à 7, um exemplo de estrutura criada fora da função main. Isso signifi- 
ca que ela poderá ser usada em qualquer parte do programa, não ficando restrita a algum bloco de chaves. 
Na linha 12, temos a declaração da variável contas, fazendo uso do tipo Banco. Observe que contas é uma 
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matriz com 4 linhas e 3 colunas. Cada posição dessa matriz terá espaço para armazenar três valores: num, 
titular e saldo. À seguir mostramos uma representação gráfica da matriz contas. 


0 1 2 
num num num 

0 titular titular titular 
saldo saldo saldo 
num num num 

as titular titular titular 
Variável 
saldo saldo saldo 
contas 

num num num 

2 titular titular titular 
saldo saldo saldo 
num num num 

3 titular titular titular 
saldo saldo saldo 


Em alguns momentos, é possível fazer a declaração da variável com a definição da estrutura, no mesmo 
bloco de comandos. Observe o exemplo 4, a seguir. 


Exemplo 4: 

1. finclude <stdio.h> 

Ds SOE, 

3. int main() 

4. { 

Do struct 

6. { int codigo; 
o char descricao[50]; 
8. } materiais[40]; 
9. ES 

10.> 


Alguns pontos merecem ser destacados no exemplo 4. A declaração da estrutura acontece da linha 5 à 
8. Contudo, essa estrutura não recebeu um nome (veja que simplesmente foi usada a palavra struct). Por 
essa razão, todas as variáveis que necessitam fazer uso desse tipo devem ser declaradas no mesmo bloco que 
a struct, como foi o caso do vetor de 40 posições, chamado materiais. Depois que esse bloco for finali- 
zado, nenhuma outra variável poderá ser associada a essa estrutura, já que, em virtude de não lhe ter sido 
atribuído um nome, ela não poderá ser referenciada. 


10.4.1 Acesso a membros de estruturas 


O uso de uma struct é possível por meio do acesso individual a seus membros, quer seja para gravar 
quer seja para recuperar um dado. O acesso a determinado membro da estrutura é feito informando-se o 
nome da variável, seguido por um ponto e pelo nome do membro desejado. 

A forma geral a ser utilizada é descrita abaixo: 


nome da variável do tipo estrutura.nome do membro 


À seguir, serão apresentados alguns trechos de programas, exemplificando o uso de estruturas (a nume- 
ração das linhas servem apenas para auxiliar a explicação). 


Exemplo 1: 


1. include <stdio.h> 
Pã gol 

3. int main() 

o A 
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5 struct BANCO { 

6. int numero; 

7 float saldo; 

8. char titular[35]; 
9. }; 


11. BANCO conta; 


13. printf(“Digite o número da conta: “); 

14. scanf(“3d%+*c”, conta.numero) ; 

15. printf(“Digite o nome do titular da conta: “); 
16. gets(conta.titular); 

17. printf(“Digite o saldo da conta: “); 

18. scanf(“3f%+*+c”, conta.saldo); 


No exemplo 1, pode-se ver, da linha 5 à 9, a criação de uma estrutura, chamado BANCO. Essa estrutura 
agrupa três tipos de dados: o numero, que é um inteiro; o saldo, que é um número real; e o titular, que 
é uma cadeia de caracteres. Na linha 11, é criada uma variável conta do tipo BANCO. Isso implica que os 
três membros da estrutura estão contidos nessa variável. Nas linhas 14, 16 e 18, os comandos de leitura 
scanf e gets permitem que sejam atribuídos valores aos membros numero, titular e saldo. Observe que, 
nessas três linhas, os membros da estrutura só puderam ser acessados porque foram precedidos pelo nome 
da variável conta. 


Exemplo 2: 

1. finclude <stdio.h> 

PAG RO 

3. struct EMPRESA 

4. { char nome[50]; 

SE float salario; 

6. ki 

To 

8. int main() 

So al 

10. EMPRESA funcionarios[4]; 

iss raio 

12. for (i=0; i<4, i++) 

Ss 

14. printf(“Digite o nome do funcionário %d : “, i); 
EST gets (funcionarios[i].nome); 

16. printf(“Digite o salário do funcionário 3d : “, i); 
17. scanf (“%f%*c", funcionarios[i].salario); 
do 3 

Da ooo 

20. 3 


O exemplo 2 apresenta a criação (linha 10) e o uso de um vetor de quatro posições. Cada posição desse 
vetor tem capacidade para armazenar os membros nome e salario, definidos na estrutura EMPRESA (da 
linha 3 à 6). Assim, como acontece com qualquer vetor, as posições devem ser acessadas com o uso de um 
índice. No exemplo 2, esse índice é a variável i, controlada pelo for, que permite sua variação de O até 3 
(posições definidas para vetor funcionarios). 

Após a execução de todos as iterações do for, o vetor estará completamente preenchido. A seguir, mos- 
tramos uma ilustração de como o vetor ficaria. 
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Vetor 0 E 2 3 
nome João nome Maria nome Pedro nome Lúcia 
funcionarios 
salario 1000,00 salario 5000,00 salario 1800,00 salario 2700,00 
Exemplo 3: 
WTE 
2. for( i=0; i<4; i++) 
Sd, 
4. printf(“Funcionário que ocupa a posição %d no vetor:”, i); 
Do printf(“Nome: %s”, funcionarios[i].nome); 
6. printf(“Salário: %6.2f”, funcionarios[i].salario); 
RES 
8. 


O exemplo 3 faz uso de um vetor de quatro posições, chamado funcionarios. À estrutura de repetição 
for, iniciada na linha 2, permite que as quatro posições do vetor sejam percorridas e os dados encontrados 
sejam mostrados. A seguir, pode-se ver uma simulação da execução desse pedaço de programa, consideran- 
do-se que o vetor tenha sido preenchido como ilustrado no exemplo 2. 


Memória Tela 


ionário que ocupa a posição O no vetor: 
e: João 
io: 1000,00 
ionário que ocupa a posição 1 no vetor: 
e: Maria 
Salário: 5000,00 
Funcio 
e: 
o 
o 
e: 


ionário que ocupa a posição 2 no vetor: 


Pedro 
io: 1800,00 
ionário que ocupa a posição 3 no vetor: 


Lúcia 


Salário: 2700,00 


10.5 Declaração de registros em JAVA 

Registros em JAVA são representados por classes definidas pelo usuário, em que os campos são chama- 
dos variáveis de instância ou atributos. 

Formato geral: 


[modificador de acesso] class Registro ( 
[modificador de acesso] tipo atributol; 
[modificador de acesso] tipo atributo2; 


[modificador de acesso] tipo atributoN; 
[modificador de acesso] tipo métodol( [parâmetros]) { 


} 


[modificador de acesso] tipo método2([parâmetros]) { 
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[modificador de acesso] tipo métodoN( [parâmetros]) { 


Além de conter os atributos, uma classe pode também conter métodos, ou seja, funções para manipular 
esses atributos. 
O formato geral de classe apresentado anteriormente mostra que é possível estabelecer critérios de 
acessibilidade à classe, aos atributos e aos métodos. São eles: 
a) acesso público, representado pela palavra public, indicando que a classe pode ser usada por qual- 
quer outra classe; 
b) acesso protegido, representado pela palavra protected, indicando que uma classe poderá ser usa- 
da pelas suas descendentes; 
c) acesso privado, representado pela palavra private, indicando que a classe poderá ser usada ape- 
nas dentro da classe onde ela foi definida (uma classe dentro da outra); 
d) acesso de pacote, representado pela ausência de um modificador, indicando que a classe poderá ser 
usada por qualquer outra classe que pertença ao mesmo pacote (mesma pasta). 


O estudo aprofundado sobre modificadores de acesso não faz parte dos objetivos deste livro. Sugere-se, 
para isso, leitura de livros específicos sobre linguagem JAVA. 

Uma forma de tornar mais fácil a manutenção e a busca por erros em programas é fazer com que todos 
os atributos de uma classe tenham visibilidade private. Isso significa que eles não poderão ser acessados 
diretamente por outras classes. Somente métodos específicos poderão manipular tais atributos. Assim, se 
alguma operação precisar ser alterada ou modificada, basta mexer no método responsável por tal operação. 
Normalmente, métodos que alteram valores de atributos são chamados de setters, e métodos que obtêm o 
valor dos atributos são chamados getters. 


Exemplo 1: 

1. private class Produto 

2. { private int num; 

3 private String titular; 

4. private float valor; 

5 public void setNum(int n) { 
6 num = n; 

7 } 

8 public int getNum() ( 

9. return num; 

10. } 

Mila public void setTitular(String n) { 
12. titular = n; 

T3: } 

14. public String getTitular() { 
15. return titular; 

16. } 

7 public void setValor(float v) { 
18. valor = v; 

19. } 

20. public float getValor() { 
2 return valor; 

22. } 

23.} 


No exemplo 1, uma classe Produto foi definida. Isso significa que um novo tipo de dado foi criado. Nas 
linhas 2, 3 e 4, são definidos os atributos da classe Produto. Isso quer dizer que todas as variáveis declaradas 
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desse tipo poderão armazenar três valores: num, titular e valor. Da linha 5 à 22, são definidos os métodos 
da classe, ou seja, as operações (ou funções) que cada variável desse tipo poderá realizar. 

Como os atributos da classe são private, apenas as linhas de código que estiverem dentro dessa classe 
poderão acessá-los. Assim, para permitir que esses atributos sejam utilizados em outras classes, foram cria- 
dos métodos (observe que todos são public) responsáveis por acessar (getters) e alterar (setters) os valores 
dos campos. Sendo assim, por exemplo, se for preciso alterar o atributo valor, deve-se chamar o método 
setValor(), passando o novo valor como parâmetro. Já, se for necessário acessar o conteúdo armazenado 
no atributo valor, deve-se utilizar o retorno do método getValor (). 


10.5.1 Declaração de variáveis do tipo registro em JAVA 


E importante ressaltar que, para o programa utilizar uma classe definida pelo usuário, é necessária a 
declaração de variáveis do tipo abaixo: 


nome da classe nome da variável; 


Considerando que classes representam novos tipos de dados, todas as operações e declarações realiza- 
das com os tipos predefinidos da linguagem também poderão ser realizadas com as classes. Dessa maneira, 
além de variáveis simples, vetores e matrizes, podem ser declarados como class. 


Exemplo 1: 


Produto var; 


No exemplo, a variável var é criada como uma referência ao Produto, ou seja, a variável var conterá o 
endereço de um objeto Produto. Isso significa que, logo após a declaração, o conteúdo de var é null porque 
ela está referenciando um objeto ainda não criado. 

Sendo assim, para que o objeto passe a existir (ou seja, tenha um espaço reservado na memória para si) 
e possa ser utilizado, o programa deverá executar o método construtor da classe. 

Método construtor é uma rotina que toda classe possui. Esse método pode estar claramente escrito 
ou não. Quando não estiver escrito, será executado o construtor padrão, que simplesmente faz alocação 
de memória. Quando estiver escrito, deverá possuir o mesmo nome que a classe e não poderá ter tipo de 
retorno definido (nem mesmo void). Por exemplo, se quiséssemos incrementar a classe Produto descrita 
anteriormente, poderíamos definir um construtor para ela. Observe como ficaria a seguir. O construtor é o 
método que aparece escrito da linha 5 à 10. 


l1. private class Produto 

2. { private int num; 

So private String nome; 

4. private float valor; 

5. public Produto() 

6. { System.out.println(“Inicializando os atributos”); 
Te num =0; 

8. nome = “rr, 

9. valor= 0; 

10.3 

11.public void setNum(int n) 
12.4 num = n; 

13.5 


14.public int getNum() 

15.( return num; 

16.3) 

17.public void setNome(String n) 
18.1 nome = n; 

19.) 

20.public String getNome() 

21.1 return nome; 

22.) 
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23.public void setValor(float v) 
24.4 valor = v; 

25.) 

26.public float getValor() 

27.4 return valor; 

28.) 

29.) 


Na linha 5, encontra-se o cabeçalho do construtor com as seguintes características: visibilidade pública, 
nenhum tipo de retorno definido e nome igual ao da classe. Além disso, se desejássemos, poderíamos in- 
formar entre parênteses uma lista de parâmetros, como pode acontecer com qualquer método. Assim, toda 
vez que um objeto da classe Produto for criado, as linhas 5, 6, 7, 8, 9 e 10 serão executadas, ou seja, todos 
os produtos começarão com os atributos num e valor contendo zero e com o atributo nome contendo uma 
cadeia de caracteres vazia. 

A chamada a um construtor deve ser feita seguindo a sintaxe: 


var = new Produto(); 


A partir dessa linha, o conteúdo de var deixou de ser null e realmente passou a ser referência para 
um objeto Produto, ou seja, var contém o endereço inicial do espaço de memória ocupado por um objeto. 
As linhas de declaração e de criação de um objeto podem ser unificadas da seguinte maneira: 


Produto var = new Produto (); 


Exemplo 2: 

Assim como acontece com os outros tipos de dados, uma variável pode representar um vetor ou uma 
matriz multidimensional. Para isso, será necessário: 1) criar a variável, informando que ela representará 
um vetor ou uma matriz; 2) definir o tamanho do vetor ou da matriz; 3) criar cada objeto do vetor ou da 
matriz antes de utilizá-lo. Observe o exemplo a seguir (a numeração das linhas à esquerda não faz parte do 
programa). 


1 

2. Produto exemplo[][]; 

3. exemplo = new Produto[3][6]; 

4. for(int i=0;i<3,i++) 

55 for (int j=0;j<6;j++) 

6. exemplo[i][j] = new Produto(); 
7 


Na linha 2 foi feita a declaração da variável exemplo, informando que ela será a referência para uma 
matriz bidimensional. Na linha 3, a variável exemplo foi dimensionada, ou seja, a partir desse momento o 
programa sabe que ela conterá três linhas e seis colunas. Cada posição dessa matriz armazenará o endereço 
de um objeto da classe Produto. Enquanto os objetos não forem criados pelo método construtor, as posições 
da matriz conterão null. As linhas 4 e 5 são responsáveis por duas estruturas de repetição que permitem 
percorrer toda a matriz exemplo. Assim, toda vez que a linha 6 é executada, um novo objeto é criado na 
memória e seu endereço é armazenado na variável exemplo, nas posições definidas pelos índices i e 5. 


10.5.2 Acesso a membros de classes 


Em JAVA, atributos e métodos são considerados membros de classes. Esses membros podem ser defi- 
nidos com ou sem o modificador static. Criar um membro static significa que ele pertence à classe e, 
portanto, sua utilização não está condicionada à criação de objetos (que acontece quando o método cons- 
trutor é executado). Quando um atributo é definido como static, isso significa que ele terá apenas um 
valor que será compartilhado por todos os objetos dessa classe. Para acessar um membro de uma classe, 
deve-se seguir a sintaxe: 


nomeDoObjeto.nomeDoAtributo 
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ou 


nomeDoObyjeto.nomeDoMétodo ( ) 


Especificamente para membros static, o acesso pode ser feito por meio do nome da classe, conforme 
descrito a seguir. 


nomeDaClasse.nomeDoAtributo 
ou 


nomeDaClasse.nomeDoMétodo (|) 


Exemplo 1: 

1. public class Exemplol 

Dik 

3. private static class Produto 

4. { public int num; 

Ho public String nome; 

6. public float valor; 

7. + 

8. public static void main(String args[]) 

9. { Produto p; 

10. p = new Produto(); 

Ji p.num = 1; 

12: p.nome = “geladeira”; 

So p.valor = 800; 

14. System.out.println(“Código: “ + p.num); 
r57 System.out.println(“Descrição: ” + p.nome); 
16. System.out.println(“Valor: “ + Pp.valor); 
bio | 

18.3 


No exemplo, a classe Exemplo1 tem dentro de si a definição da classe Produto, da linha 3 à 7. A classe 
Produto foi definida como private, ou seja, somente as linhas de comando que estiverem dentro da classe 
Exemplo1 poderão utilizá-la. Além disso, como o método main() é static, ele só pode utilizar variáveis 
e classes que tenham sido declaradas dentro dele ou que sejam static. Por essa razão, a classe Produto 
também foi definida como static. 

Analisando mais detalhadamente a classe Produto, podemos observar que seus atributos num, nome e 
valor foram todos definidos como public, nas linhas 4, 5 e 6. Isso quer dizer que quem conseguir acesso 
à classe Produto poderá acessá-los diretamente. Contudo, nessas mesmas linhas não foi utilizado o modi- 
ficador static, o que quer dizer que os atributos só poderão ser usados depois da criação de um objeto 
Produto. Essa criação acontece na linha 10, onde a variável p recebe o endereço de memória de um novo 
objeto. A partir daí, da linha 11 à 16, os atributos, que são públicos, são manipulados diretamente. Obser- 
ve, entretanto, que as linhas que manipulam os atributos da classe Produto estão sempre fazendo uso do 
objeto p criado na linha 10. 


Exemplo 2: 

Conteúdo do arquivo Produto.java 

1. public class Produto 

2. { private int num; 

3 private String nome; 

a private float valor; 

5 public void setNum(int n) 
6 { num =n; 

1 } 
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8. 
9. 


10. 
IL, 


T2 
137 
14. 
15 
16. 
I7 
18. 
MOR 
20. 
Pilo 
22. 
23. 


} 


public int getNum() 

{ return num; 

} 

public void setNome(String 
{ nome = n; 

+ 

public String getNome() 

{ return nome; 

} 

public void setValor(float 
{ valor = v; 

+ 

public float getValor() 

{ return valor; 

} 


Conteúdo do arquivo Exemplo2.java 


1 
2 
3 
4 
Do 
6 
7 
8. 
9. 
10. 


db e, 
12, 


} 


} 


p.setNum(1); 
p.setNome(“geladeira"); 
p.setValor(800); 


System.out.println(“Código: 


n) 


v) 


. public class Exemplo2 
{ 
public static void main(String 
{ Produto p = new Produto(); 


“ 


System.out.println(“Descrição: 


System.out.println(“Valor: 


“ 


args[]) 


+ p.getNum()); 
“ + p.getNome()); 


+ p.getValor()); 


O exemplo 2 faz uso de dois arquivos que devem estar na mesma pasta (neste livro, não abordaremos 
a utilização de package). O primeiro arquivo chama-se Produto. java e o segundo arquivo denomina-se 
Exemplo2. java. 

Vamos começar analisando mais detalhadamente a classe Produto. Observe que ela é public, ou seja, 
pode ser usada por qualquer aplicação. Porém, seus atributos não podem ser acessados diretamente, uma 
vez que foram definidos como private nas linhas 2, 3 e 4. Por essa razão, da linha 5 à 22, foram criados 
métodos public capazes de alterar (setters) e de capturar (getters) o valor de cada atributo. 

Observando agora a classe Exemplo2, verificamos que um objeto Produto foi criado na linha 4. A partir 
daí, da linha 5 à 7, foi possível chamar os métodos para alterar o valor dos atributos. Da linha 8 à 10, foi 
possível chamar os métodos para obter o valor dos atributos e mostrá-los na tela. Observe, entretanto, que 
para chamar algum método da classe produto, foi sempre necessário fazer referência à variável p, criada na 


linha 4. 
Exemplo 3: 
Conteúdo do arquivo Produto.java 
1 public class Produto 
2 { private int num; 
Elo private String nome; 
4. private float valor; 
5 public void setNum(int n) 
6 


{ num = n; 
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Ta } 

8. public int getNum() 

9. { return num; 

10. } 

JL o public void setNome(String n) 
12. { nome = n; 

13 } 

14. public String getNome() 

Uso { return nome; 

16. } 

A7 public void setValor(float v) 
18. { valor = v; 

19. } 

20. public float getValor() 

21. { return valor; 

22. } 

23e Y 


Conteúdo do arquivo Exemplo3.java 


1. public class Exemplo3 

2. + 

3 public static void main(String args[]) 

4. { Produto p[] = new Produto[4]; 

Do inte É 

6 for (j=0;)<3;j++) 

7 { 

8. p[j] = new Produto(); 

9. p[j].setNum(j+1); 

10. p[j].setNome(“Produto “+ (j+1)); 

Mile, p[j].setValor((j+1)*100); 

12% } 

13 for (j=0;j<3;j++) 

14. { System.out.println(“Dados do produto na posição: “ + j); 
Iso System.out.println(“Código: ” + p[5j].getNum()); 

16. System.out.println(“Descrição: “ + p[j].getNome()); 
ii System.out.println(“Valor: “ + p[j].getValor()); 
18. } 

19. } 

20. 3 


O exemplo 3 faz uso de dois arquivos, que devem estar na mesma pasta (neste livro, não abordaremos 
a utilização de package). O primeiro arquivo se chama Produto. java e o segundo arquivo, Exemplo3. java. 

Vamos começar analisando mais detalhadamente a classe Produto. Observe que ela é public, ou seja, 
pode ser usada por qualquer aplicação. Porém, seus atributos não podem ser acessados diretamente, uma 
vez que foram definidos como private nas linhas 2, 3 e 4. Por essa razão, da linha 5 à 22 foram criados 
métodos public capazes de alterar (setters) e de capturar (getters) o valor de cada atributo. 

Observando agora a classe Exemplo3, verificamos que um objeto Produto foi criado na linha 4, infor- 
mando que se trata de um vetor com quatro posições. Assim, devem ser criados quatro objetos Produto que 
terão seus endereços armazenados no vetor p. 

A linha 8 está contida em uma estrutura de repetição, especialmente criada para percorrer todas as 
posições do vetor p. Assim, essa linha será executada quatro vezes. Em cada execução, um novo objeto 
Produto é criado e seu endereço é guardado em uma posição de p. Depois que o objeto é criado, ele pode 
chamar os métodos para alteração do valor de seus atributos, conforme pode ser visto nas linhas 9, 10 e 
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11. Nas linhas 15, 16 e 17, são chamados os métodos para capturar o valor dos atributos e, então, mostrá- 
-los na tela. Observe, entretanto, que as linhas que chamam algum método da classe Produto estão sempre 
fazendo uso de um objeto do vetor p, acessado por meio do índice 5. 

A seguir, exemplificamos a execução das estruturas de repetição escritas no método main, da classe 
Exemplo3. java. 

À primeira estrutura de repetição, escrita da linha 6 à 12, aloca espaços de memória para guardar in- 
formações dos produtos, como exemplificado na tabela a seguir. 


0 1 2 3 

Vetorp num |1 num 2 num 3 num 4 
nome (Produto 1 nome (Produto 2 nome Produto 3 nome Produto 4 
valor 100.00 valor 200.00 valor 300.00 valor 400.00 


À segunda estrutura de repetição, escrita da linha 13 à 18, mostra o conteúdo dos atributos de todos os 
objetos Produto do vetor p. À seguir, mostramos uma simulação de execução, considerando o exemplo de 
vetor apresentado anteriormente. 


Memória Tela 


Dados do produto na posição: 0 
Código: 1 

Descrição: Produto 1 

Valor: 100.00 

Dados do produto na posição: 1 
Código: 2 

Descrição: Produto 2 

Valor: 200.00 

Dados do produto na posição: 2 
Código: 3 

Descrição: Produto 3 

Valor: 300.00 

Dados do produto na posição: 3 
Código: 4 

Descrição: Produto 4 

Valor: 400.00 


EXERCÍCIOS RESOLVIDOS 


BEER Faça um programa que realize o cadastro de contas bancárias com as seguintes informações: número 
da conta, nome do cliente e saldo. O banco permitirá o cadastramento de apenas 15 contas e não po- 
derá haver mais que uma conta com o mesmo número. Crie o menu de opções a seguir. 


Menu de opções: 


1. Cadastrar contas. 

2. Visualizar todas as contas de determinado cliente. 

3. Excluir a conta com menor saldo (supondo a não existência de saldos iguais). 
4. Sair. 
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(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE conta[15] REGISTRO (num, saldo NUMÉRICO, nome LITERAL) 
i, op, posi, achou, num conta, menor saldo NUMÉRICO 
nome cliente LITERAL 
PARA i +- 1 ATÉ 15 FAÇA INÍCIO 
conta[i].num <- 0 
conta[i].nome + ” 
conta[i].saldo +- 0 
FIM 
posi <- 1 
REPITA 


ESCREVA “Menu de Opções” 
ESCREVA “1 — Cadastrar contas” 
ESCREVA “2 — Visualizar todas as contas de determinado cliente” 
ESCREVA “3 — Excluir conta de menor saldo” 
ESCREVA “4 — Sair” ESCREVA “Digite sua opção" 
LEIA op 
SE op < 1 OU op > 4 
ENTÃO ESCREVA “Opção nválida” 
SE op = 1 
ENTÃO INÍCIO 
SE posi > 15 
ENTÃO ESCREVA “Todas as contas já foram cadastradas !” 
SENÃO INÍCIO 
achou =<- 0 
ESCREVA “Digite o número da conta a ser incluída” 
LEIA num conta 
PARA i + 1 ATÉ posi - 1 FAÇA 
INÍCIO 
SE num conta = conta[i].num 
ENTÃO achou ©- 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Já existe conta cadastrada com 
- esse número” 
SENÃO INÍCIO 
conta[posi] <- num conta 
ESCREVA “Digite o nome do cliente” 
LEIA conta[posi].nome 
ESCREVA “Digite o saldo do cliente” 
LEIA conta[posi].saldo 
ESCREVA “Conta cadastrada com sucesso” 
posi « posi + 1 
FIM 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
ESCREVA “Digite o nome do cliente a ser consultado” 
LEIA nome cliente 
achou +< 0 
PARA i +- 1 ATÉ posi - 1 FAÇA 
INÍCIO 
SE conta[i].nome = nome cliente 
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ENTÃO INÍCIO 
ESCREVA conta[i].num, conta[i].saldo 
achou ©- 1 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe conta cadastrada para este cliente” 
FIM 
SE op = 3 
ENTÃO INÍCIO 
SE posi = 1 
ENTÃO “Nenhuma conta foi cadastrada” 
SENÃO INÍCIO 
menor saldo + conta[1].saldo 
achou — 1 
AL RES) 
ENQUANTO i < posi FAÇA 
INÍCIO 
SE conta[i].saldo < menor saldo 
ENTÃO INÍCIO 
menor saldo + conta[i]. saldo 
achou «© i 
FIM 
I e l 
FIM 
PARA i < achou ATÉ posi - 1 FAÇA 
INÍCIO 
conta[i-1].num - conta[i].num 
conta[i-1].nome +- conta[i].nome 
conta[i-l].saldo - conta[i].saldo 
FIM 
ESCREVA “Conta excluída com sucesso” 
posi « posi — 1 
FIM 
FIM 
ATÉ op = 4 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 


E NEXERCACAP10NPASCALNEX1.PAS e \EXERC\CAP10\PASCAL\EX1.EXE 


VL Ra SoLução: 


E \EXERC\CAP10\C++\EX1.CPP e NEXERCACAP1IONC++NEX1. EXE 


RB WIAN SoLução: 
E \EXERC\CAP10\JAVA\EX1.java e \EXERC\CAP10\JAVA\EX1.class 
IFA Uma empresa prestadora de serviços armazena informações sobre os serviços prestados. Sabe-se que a 
empresa pode realizar no máximo três serviços diariamente. É de interesse de sua direção manter um 
histórico mensal (30 dias) sobre os serviços prestados. 
À empresa realiza quatro tipos de serviços: 1) pintura; 2) jardinagem; 3) faxina e 4) reforma em geral. 
Cada serviço realizado deve ser cadastrado com as seguintes informações: número do serviço, valor do ser- 
viço, código do serviço e código do cliente. 


Cadastre os quatro tipos de serviços (código e descrição) que a empresa poderá realizar. Para isso, uti- 
lize um vetor de quatro posições. 
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O programa deverá mostrar o seguinte menu de opções: 

Cadastrar os tipos de serviços. 

Cadastrar os serviços prestados. 

Mostrar os serviços prestados em determinado dia. 

Mostrar os serviços prestados dentro de um intervalo de valor. 

Mostrar um relatório geral (separado por dia), que exiba, inclusive, a descrição do tipo do serviço. 
Finalizar. 


ye poor 


Para a opção 1: deve-se cadastrar os tipos de serviços oferecidos pela empresa, com código e descrição. 

Para a opção 2: deve-se considerar que deverão ser cadastrados os serviços prestados ao longo do mês. 

Em cada dia podem ser cadastrados, no máximo, três serviços prestados. 

Utilize uma matriz capaz de armazenar em cada posição todas as informações referentes a um serviço 
prestado. Cada linha representa um dia do mês. Dessa maneira, considere a matriz com dimensão 30 x 3. 

Solicite o dia em que o serviço foi prestado e as demais informações. 

Lembre-se de que a empresa só pode prestar os serviços que já tenham sido cadastrados no vetor de 
tipo de serviços. 

Caso o usuário digite um código de tipo de serviço inválido, o programa deverá mostrar uma mensa- 
gem de erro. 

Quando o usuário tentar cadastrar mais de três serviços prestados em um mesmo dia, também deverá 
mostrar uma mensagem de erro. 


Para a opção 3: o programa deverá receber o dia que se deseja consultar e mostrar os respectivos ser- 
viços prestados. 

Para a opção 4: o programa deverá receber o valor mínimo e o valor máximo e mostrar os serviços 
prestados que estiverem nesse intervalo. 

Para a opção 5: o programa deverá mostrar todos os serviços prestados, conforme o exemplo a seguir. 


DIA 01 

Nº do serviço Valor do serviço Código do serviço Descrição Código do cliente 
100 R$ 200,00 1 Pintura 1 
150 R$ 100,00 3 Faxina 5 

DIA 02 

Nº do serviço Valor do serviço Código do serviço Descrição Código do cliente 
301 R$ 600,00 4 Reforma em geral 3 
280 R$ 352,00 1 Pintura 2 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE tipos[4] REGISTRO (cod NUMÉRICO, desc LITERAL) 
serv[30,3] REGISTRO (num, valor, cod serv, cod cliente NUMÉRICO ) 
i, j, op, codigo serv, achou, conta tipo NUMÉRICO 
dia, codigo cliente, valor serv, num serv, valida NUMÉRICO 
valor inicial, valor final, k NUMÉRICO 
desc serv LITERAL 
conta tipo <- 1 
PARA i +- 1 ATÉ 30 FAÇA 
INÍCIO 
PARA j « 1 ATÉ 3 FAÇA 
INÍCIO 
serv[i, j].num <- 0 
serv[i,j].valor <- 0 
serv[i,j].cod_serv + 0 
serv[i,j].cod_cliente <- 0 


Capítulo 10 Registro | 353 


FIM 
FIM 
REPITA 
ESCREVA “Menu de Opções” 
ESCREVA “1 - Cadastrar os tipos de serviços” 
ESCREVA “2 - Cadastrar os serviços prestados” 
ESCREVA “3 - Mostrar os serviços prestados em determinado dia” 
ESCREVA “4 - Mostrar os serviços prestados dentro de um intervalo de valor” 
ESCREVA “5 - Mostrar um relatório geral, separado por dia” 
ESCREVA “6 - Finalizar” 
ESCREVA “Digite sua opção” 
LEIA op 
SE op < 1 O op > 6 
ENTÃO ESCREVA “Opção Inválida” 
SE op = 1 
ENTÃO INÍCIO 
SE conta tipo > 4 
ENTÃO ESCREVA “Cadastro de tipos de serviço lotado. 
SENÃO INÍCIO 
ESCREVA “Digite o codigo do serviço a ser cadastrado” 
LEIA codigo serv 
achou + 0 
PARA i « 1 ATÉ conta tipo - 1 FAÇA 
INÍCIO 
SE tipos[i].cod = codigo serv 
ENTÃO achou © i 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Já existe tipo de serviço cadastrado com 
- esse codigo” 
SENÃO INÍCIO 
ESCREVA “Digite a descrição do tipo de serviço a 
- ser cadastrado” 
LEIA desc serv 
tipos[conta tipo].cod + codigo serv 
tipos[conta tipo].desc + desc serv 
ESCREVA “Tipo de serviço cadastrado com sucesso” 
conta tipo + conta tipo + 1 


FIM 
FIM 


FIM 
SE op = 2 
ENTÃO INÍCIO 
ESCREVA “Digite o dia em que deseja cadastrar o serviço prestado” 
LEIA dia 
achou <- 0 
PARA j - 1 ATÉ 3 FAÇA 
INÍCIO 
SE serv[dia, j] num = 0 
ENTÃO achou © j 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Todos os serviços prestados neste dia já foram 
= cadastrados” 
SENÃO INÍCIO 
ESCREVA “Digite o código do serviço a ser cadastrado" 
LEIA codigo_serv 
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valida <- 0 
PARA i - 1 ATÉ conta tipo - 1 FAÇA 
INÍCIO 
SE tipos[i].cod = codigo serv 
ENTÃO valida + 1 
FIM 
SE valida = 0 
ENTÃO ESCREVA “Código de serviço inválido” 
SENÃO INÍCIO 
ESCREVA “Digite o número do serviço” 
LEIA num serv 
ESCREVA “Digite o valor do serviço” 
LEIA valor serv 
ESCREVA “Digite o código do cliente” 
LEIA codigo cliente 
serv[dia, achou].num <- num serv 
serv[dia, achou].valor + valor serv 
serv[dia, achou].cod serv + codigo serv 
serv[dia, achou].cod cliente « codigo cliente 
ESCREVA “Serviço prestado cadastrado com 
- sucesso” 
FIM 
FIM 


SE op = 3 
ENTÃO INÍCIO 
ESCREVA “Digite o dia em que deseja consultar os serviços prestados” 
LEIA dia 
achou < 0 
PARA j - 1 ATÉ 3 FAÇA 
INÍCIO 
SE serv[dia, jJ.num + 0 
ENTÃO achou © 1 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhum serviço foi prestado neste dia” 
SENÃO INÍCIO 
ESCREVA “Serviços prestados no dia”, dia 
PARA j — 1 ATÉ 3 FAÇA 
INÍCIO 
SE serv[dia, j].num = 0 
ENTÃO INÍCIO 
ESCREVA serv[dia, j].num, serv[dia, j].valor 
ESCREVA servídia, j].cod serv 
PARA i - 1 ATÉ conta tipo - 1 FAÇA 
INÍCIO 
SE tipos[i].cod = serv[dia, j].cod serv 
ENTÃO ESCREVA tipos[i].desc 
FIM 
ESCREVA serví[dia, j]. cod cliente 
FIM 
FIM 
FIM 
FIM 
SE op = 4 
ENTÃO INÍCIO 
ESCREVA “Digite o valor inicial” 
LEIA valor inicial 
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ESCREVA “Digite o valor final” 
LEIA valor final 
achou < 0 
PARA i +- 1 ATÉ 30 FAÇA 
INÍCIO 
PARA j - 1 ATÉ 3 FAÇA 
INÍCIO 
SE serv[i,j].valor>=valor inicial E serv[i,j]. valor<=valor final 
ENTÃO INÍCIO 
achou <- 1 
ESCREVA serv[i, j].num, serv[i, j].valor 
ESCREVA serv[i, j].cod serv 
PARA k - 1 ATÉ conta tipo - 1 FAÇA 
INÍCIO 
SE tipos[k].cod = serv[i, j].cod serv 
ENTÃO ESCREVA tipos[k].desc 
FIM 
ESCREVA serv[i, j].cod cliente 
FIM 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhum serviço prestado está entre os valores citados” 
FIM 
SE op = 5 
ENTÃO INÍCIO 
achou < 0 
PARA i - 1 ATÉ 30 FAÇA 
INÍCIO 
ESCREVA “Dia “, i 
PARA j - 1 ATÉ 3 FAÇA 
INÍCIO 
SE serv[i,j].num + 0 
ENTÃO INÍCIO 
achou <- 1 
ESCREVA serv[i,j].num, serv[i,j].valor 
ESCREVA serv[i,j].cod serv 
PARA k - 1 ATÉ conta tipo — 1 FAÇA 
INÍCIO 
SE tipos[k].cod = serv [i,5j].cod serv 
ENTÃO ESCREVA tipos[k].desc 
FIM 
ESCREVA serv[i, j].cod cliente 
FIM 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhum serviço prestado foi cadastrado” 
FIM 


ATÉ op = 6 
FIM ALGORITMO. 
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PASCAL SOLUÇÃO: 


VEXERCACAP10NPASCALNEX2.PAS e \EXERC\CAP10\PASCAL\EX2.EXE 


VETA SoLução: 


\EXERC\CAP10\C++\EX2.CPP e NEXERCACAPIONC++NEX2. EXE 


RANMA SoLução: 


\EXERC\CAP10\JAVA\EX2.java e NEXERCICAPIONJAVANEX2.class 


BEAR Faça um programa que utilize os registros a seguir. 


CLIENTES DOCUMENTOS 
cod cli num doc 
nome cod cli 
fone data venc 
endereco data pag 
valor 
juros 


Sabe-se que um documento só pode ser cadastrado para um cliente que já exista. Considere que podem 
existir, no máximo, 15 clientes e 30 documentos. Crie um vetor para clientes e outro para documentos. Crie 
um menu para a realização de cada uma das operações especificadas a seguir. 


a) 


b) 


Cadastrar clientes — não pode existir mais que um cliente com o mesmo código. 

Cadastrar documentos — ao cadastrar um documento, se a data de pagamento for maior que a data de venci- 
mento, calcular o campo “juros” do registro documentos (5% sobre o valor original do documento). 

Excluir clientes — um cliente só poderá ser excluído se não existir nenhum documento associado a ele. 
Excluir documentos individuais — por meio de seu número. Caso o documento não exista, o programa deverá 
mostrar a mensagem Documento não encontrado. 


Excluir documentos por cliente — o programa deverá informar o código do cliente e excluir todos os seus 
documentos. Caso o cliente não exista, deverá mostrar a mensagem Cliente não encontrado. 

Excluir documentos por período — o programa deverá informar a data inicial e a data final e excluir todos os 
documentos que possuam data de vencimento nesse período. 

Alterar as informações sobre os clientes — só não pode ser alterado o código do cliente. 

Mostrar o total de documentos de determinado cliente. 


Sair. 


Quando forem excluídos clientes ou documentos, os vetores deverão ser reorganizados, ou seja, todas 
as posições não preenchidas dos vetores deverão ficar no final. Exemplo: se for necessário excluir o número 
8 do vetor a seguir, tanto o 9 quanto o 1 deverão ser movidos uma casa para a esquerda e a última posição 
deverá ficar livre para uma nova inclusão. 


Vetor inicial 
12 5/8,9 1 


Vetor modificado com uma 
posição livre ao final 


12 2 9 1 
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(AJLIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE clientes[15] REGISTRO (cod cli NUMÉRICO, nome, fone, ende LITERAL) 
docs[30] REGISTRO (num doc, cod cli, dv, mv, av, dp, mp, ap, valor, juros NUMÉRICO) 
posi, op, i, cliente livre, doc livre NUMÉRICO 
achou, achou2, codigo, numero, diav, mesv, anov NUMÉRICO 
diap, mesp, anop, valor, juros, total NUMÉRICO 
nome, fone, ende LITERAL 
ciliientemhiyare nl 
doc livre « 1 
REPITA 
ESCREVA “Menu de Opções” 
ESCREVA “1 - Cadastrar clientes” 
ESCREVA “2 - Cadastrar documentos” 
ESCREVA “3 — Excluir clientes” 
ESCREVA “4 — Excluir documentos individuais” 
ESCREVA “5 — Excluir documentos por cliente” 
ESCREVA “6 — Excluir documentos por período” 
ESCREVA “7 — Alterar clientes” 
ESCREVA “8 — Totalizar documentos” 
ESCREVA “9 — Sair” 
ESCREVA “Digite sua opção” 
LEIA op 
SE op < 1 O op > 9 
ENTÃO ESCREVA “Opção inválida” 
SE op = 1 
ENTÃO INÍCIO 
SE cliente livre > 15 
ENTÃO ESCREVA “Cadastro de clientes lotado” 
SENÃO INÍCIO 
ESCREVA “Digite o código do cliente a ser cadastrado” 
LEIA código 
achou ©- 0 
PARA i + 1 ATÉ cliente livre - 1 FAÇA 
INÍCIO 
SE clientes[i].cod_cli = codigo 
ENTÃO achou + 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Já existe cliente cadastrado com esse código" 
SENÃO INÍCIO 
ESCREVA “Digite o nome do cliente” 
LEIA nome 
ESCREVA “Digite o telefone do cliente” 
LEIA fone 
ESCREVA “Digite o endereço do cliente” 
LEIA ende 
clientes[cliente livre].cod cli « código 
clientes[cliente livre].nome <« nome 
clientes[cliente livre].fone <« fone 
clientes[cliente livre].ende + ende 
ESCREVA “Cliente cadastrado com sucesso” 
cliente livre & cliente livre + 1 
FIM 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
SE doc livre > 30 
ENTÃO ESCREVA “Cadastro de documentos lotado” 
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SENÃO INÍCIO 
ESCREVA “Digite o número do documento a ser cadastrado” 
LEIA numero 


achou © 0 
PARA i + 1 ATÉ doc livre — 1 FAÇA 


INÍCIO 


SE docs[i].num doc = numero 
ENTÃO achou <« 1 


FIM 


SE achou = 1 


FIM 
FIM 
SE op = 3 
ENTÃO INÍCIO 


ENTÃO ESCREVA “Já existe um documento cadastrado com esse código” 
SENÃO INÍCIO 
ESCREVA “Digite o código do cliente dono do documento” 
LEIA código 
achou « 0 
PARA i + 1 ATÉ cliente livre - 1 FAÇA 
INÍCIO 
SE clientes[i].cod cli = código 
ENTÃO achou + 1 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe cliente cadastrado com esse código” 
SENÃO 
INÍCIO 
ESCREVA “Digite a data do vencimento do documento” 
LEIA diav, mesv,anov 
ESCREVA “Digite a data do pagamento do documento” 
LEIA diap, mesp, anop 
ESCREVA “Digite o valor do documento” 
LEIA valor 
SE anop > anov 
ENTÃO juros + valor * 5/100 
SENÃO 
SE anop = anov 
ENTÃO SE mesp > mesv 
ENTÃO juros + valor * 5/100 
SENÃO 
SE mesp = mesv 
ENTÃO 
SE diap > diav 
ENTÃO juros - valor * 5/100 
SENÃO juros < 0 
docs[doc livre].num doc + numero 


docs[doc livre].cod cli +- codigo 


docs[doc livre].dv +- diav 
docs[doc livre].mv +- mesv 
docs[doc livre].av +- anov 
docs[doc livre].dp +- diap 
docs[doc livre].mp +- mesp 


docs[doc livre].ap <« anop 

docs[doc livre].valor + valor 

docs[doc livre].juros + juros 

ESCREVA “Documento cadastrado com sucesso” 


doc livre = doc livre + 1 
FIM 
FIM 


ESCREVA “Digite ocódigo do cliente a ser excluído” 


LEIA codigo 
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achou <- 0 
PARA i + 1 ATÉ cliente livre — 1 FAÇA 
INÍCIO 
SE clientes[i].cod_cli = codigo 
ENTÃO INÍCIO 
achou « 1 
posi « i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe cliente cadastrado com esse código” 
SENÃO INÍCIO 
achou <- 0 
PARA i + 1 ATÉ doc livre — 1 FAÇA 
INÍCIO 
SE docs[i].cod cli = codigo 
ENTÃO achou <- 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Este cliente não pode ser excluído, possui documento” 
SENÃO INÍCIO 
PARA i - posi ATÉ cliente livre - 2 FAÇA 
INÍCIO 
clientes[i].cod cli - clientes[i+l]. cod cli 
clientes[i].nome - clientes[i+1].nome 
clientes[i].fone « clientes[i+l].fone 
clientes[i].ende - clientes[i+l].ende 
FIM 
cliente livre + cliente livre — 1 
ESCREVA “Cliente excluído com sucesso” 
FIM 
FIM 
FIM 
SE op = 4 
ENTÃO INÍCIO 
ESCREVA “Digite o número do documento a ser excluído” 
LEIA numero 
achou <- 0 
PARA i + 1 ATÉ doc_livre FAÇA 
INÍCIO 
SE docs[i].num doc = numero 
ENTÃO INÍCIO 
achou « 1 
posi « i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe documento cadastrado com esse número” 
SENÃO INÍCIO 
PARA i - posi ATÉ doc livre - 2 FAÇA 
INÍCIO 
docs[i].num doc +- docs[i+1].num doc 
docs[i].cod cli +- docs[i+l].cod cli 
docs[i].dv docs[i+1].dv 
docs[i].mv docs[i+1].mv 
docs[i+l].av 
docs[it+1l].dp 
docs[i+1].mp 
docs[i].ap +- docs[i+l].ap 


docs[i].av 
docs[il].dp 


RR E 


docs[i].mp 


docs[i].valor +- docs[itl].valor 
docs[il].juros « docs[it+l].juros 
FIM 
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ESCREVA “Documento excluído com sucesso” 
doc livre + doc livre - 1 
FIM 
FIM 
SE op = 5 
ENTÃO INÍCIO 
ESCREVA “Digite o código do cliente do qual deseja excluir os documentos” 
LEIA codigo 
achou + 0 
PARA i < 1 ATÉ cliente livre — 1 FAÇA 
INÍCIO 
SE clientes[i].cod cli = codigo 
ENTÃO achou — 1 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe cliente cadastrado com esse código” 
SENÃO INÍCIO 
SE doc livre = 1 
ENTÃO ESCREVA “Não existe nenhum documento cadastrado” 
SENÃO INÍCIO 
k 1 
achou + 0 
ENQUANTO k < doc_livre FAÇA 
INÍCIO 
SE codigo = docs[k].cod cli 
ENTÃO INÍCIO 
PARA i + k ATÉ doc livre - 2 FAÇA 
INÍCIO 
achou + 1 
docs[i].num doc +- docs[i+1].num doc 
docs[i].cod cli +- docs[i+l].cod cli 
docs[i].dv - docs[i+l].dv 
docs[i].mv < docs[i+1].mv 
docs[i].av - docs[i+l].av 
docs[i].dp =- docs[i+1l].dp 
docs[i].mp - docs[i+1].mp 
docs[i].ap « docs[i+l].ap 
docs[i].valor -+ docs[it+l].valor 
docs[il].juros « docs[it+l].juros 
FIM 
doc livre + doc livre — 1 
FIM 
SENÃO k e k + 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Documentos excluídos com sucesso" 
SENÃO ESCREVA “Não existe documento para este cliente" 
FIM 
FIM 
FIM 
SE op = 6 
ENTÃO INÍCIO 
ESCREVA “Digite a data inicial dos documentos que serão excluídos” 
LEIA dia inicial, mes inicial, ano inicial 
ESCREVA “Digite a data final dos documentos que serão excluídos” 
LEIA dia final, mes final, ano final 
achou? — 0 
ENQUANTO i < doc livre FAÇA 
INÍCIO 
achou — 0 
SE docs[i].av > ano inicial E docs[i].av < ano final 
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ENTÃO INÍCIO 
posi —i 
achou — 1 
FIM 
SENÃO INÍCIO 
SE docs[i].av = ano inicial 
ENTÃO INÍCIO 
SE docs[i].mv > mês inicial 
ENTÃO INÍCIO 
posi « iï 
achou « 1 
FIM 
SENÃO INÍCIO 
SE docs[i].mv = mês inicial 
ENTÃO INÍCIO 
SE docs[i].dv >= dia inicial 
ENTÃO INÍCIO 
posi <- i 
achou « 1 
FIM 
FIM 


FIM 
SENÃO INÍCIO 
SE docs[i].av = ano final 
ENTÃO INÍCIO 
SE docs[i].mv < mês final 
ENTÃO INÍCIO 
posi -i 
achou © 1 
FIM 
SENÃO INÍCIO 
SE docs[i].mv = mês_final 
ENTÃO INÍCIO 
SE docs[i].dv < dia final 
ENTÃO INÍCIO 


posi—l 
achou + 1 
FIM 
FIM 
FIM 
FIM 
FIM 
FIM 
SE achou = 1 ENTÃO 
INÍCIO 


achou? + 1 
PARA j — posi ATÉ doc livre - 2 FAÇA 
INÍCIO 
docs[5j].num doc +- docs[j+1].num doc 
docs[j].cod cli +- docs[j+1l].cod cli 
docs[j].dv docs[j+1].dv 
docs[j].mv docs[j+1].mv 
docs[j+1].av 
docs[jt+1].dp 
docs[j+1].mp 


docs[j].av 
docs[j].dp 
docs[5j].mp 


ia AR 


docs[j].ap +- docs[j+1l].ap 
docs[j].valor +- docs[jtl].valor 
docs[j].juros +- docs[j+l].juros 
FIM 
doc livre + doc livre - 1 
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FIM 
SE op 


FIM 
SENÃO i — i+1 
FIM 
SE achou2 = 0 
ENTÃO ESCREVA “Não existe documento cadastrado neste período” 
SENÃO ESCREVA"Documentos do período excluídos com sucesso” 


= 7 


ENTÃO INÍCIO 


SE op = 


ESCREVA “Digite o código do cliente a ser alterado” 
LEIA código 
achou + 0 
PARA i « 1 ATÉ cliente livre - 1 FAÇA 
INÍCIO 
SE clientes[i].cod cli = codigo 
ENTÃO INÍCIO 
achou + 1 
posi « i 
FIM 
FIM 
SE achou = 0 


ENTÃO ESCREVA “Não existe cliente cadastrado com esse código para ser alterado” 


SENÃO INÍCIO 
ESCREVA “Digite o novo nome do cliente” 
LEIA nome 
ESCREVA “Digite o novo telefone do cliente” 
LEIA fone 
ESCREVA “Digite o novo endereço do cliente” 
LEIA ende 
clientes[posi].nome + nome 
clientes[posi].fone +- fone 
clientes[posi].ende +- ende 
ESCREVA “Cliente alterado com sucesso” 
FIM 
FIM 
8 


ENTÃO INÍCIO 


ATÉ op 


ESCREVA “Digite o código do cliente do qual deseja totalizar os documentos” 
LEIA código 
achou + 0 
PARA i « 1 ATÉ cliente livre - 1 FAÇA 

INÍCIO 

SE clientes[i].cod cli = codigo 
ENTÃO achou © 1 

FIM 
SE achou = 0 

ENTÃO ESCREVA “Não existe cliente cadastrado com esse código” 

SENÃO INÍCIO 

total <- 0 
PARA i - 1 ATÉ doc livre - 1 FAÇA 
INÍCIO 
SE docs[i].cod cli = codigo 
ENTÃO INÍCIO 
total +- total + docs[i].valor 
total « total + docs[il].juros 
FIM 
FIM 


ESCREVA “Total dos documentos do cliente de código “, codigo,” = 


FIM 
FIM 
= 8) 


FIM ALGORITMO. 
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PASCAL SOLUÇÃO: 
Gree] \EXERC\CAP10\PASCAL\EX3.PAS e \EXERC\CAP10\PASCAL\EX3.EXE 


eylen TE SoLuçÃo: 
ED \EXERC\CAP10\C++\EX3.CPP e \EXERC\CAP10\C++\EX3.EXE 


BAIA SOLUÇÃO: 
Es VEXERCACAPIONJAVANEX3.java e NEXERCICAPIONJAVANEX3.class 


EA Faça um programa que efetue reserva de passagens aéreas de determinada companhia. O programa 
deverá ler os números dos aviões e o número de lugares disponíveis em cada um. Utilize um vetor de 
quatro posições, no qual cada posição representa um avião, e outro vetor também de quatro posições 
para armazenar os lugares disponíveis. 

O programa deverá mostrar o seguinte menu de opções: 
1. Cadastrar o número dos aviões. 

Cadastrar o número de lugares disponíveis em cada avião. 

Reservar passagem. 

Consultar por avião. 


Consultar por passageiro. 


A E o 


Finalizar. 


Imagine que poderão ser registradas até 60 reservas e que cada uma deverá possuir o número do avião 
e o nome do passageiro. 

Para realizar a opção 1, deverá ser solicitado ao usuário o número dos quatro aviões disponíveis. 

Para realizar a opção 2, deverá ser solicitado ao usuário o número de lugares disponíveis em cada avião 
cadastrado na opção 1. 

Para realizar a opção 3, deverá ser verificado se o número do avião digitado é válido. Posteriormente, 
checar se, no avião escolhido, ainda existe lugar disponível. Caso exista, o programa deverá diminuir o 
total de vagas e mostrar a mensagem Reserva confirmada. Caso contrário, deverá mostrar a mensagem 
Voo lotado. Observe que não podem ser feitas mais de 60 reservas. 

Para realizar a opção 4, deverá ser solicitado o número do avião desejado e, posteriormente, deverão 
ser exibidas todas as suas reservas. 

Para realizar a opção 5, deverá ser solicitado o nome do passageiro e, posteriormente, deverão ser exi- 
bidas todas as reservas feitas em seu nome. 

A opção 6 encerra o programa. 


(AILISIOJRN ITIMO) Sorução: 


ALGORITMO 

DECLARE avi[4], lug[4] NUMÉRICO 
reservas [60] REGISTRO (num avi NUMÉRICO, nome LITERAL) 
i, pos livre, op, achou, numero, posi NUMÉRICO 
nome LITERAL 

PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
avi[i] — 0 
lug[2] — 0 
FIM 
PARA i — 1 ATÉ 60 FAÇA 
INÍCIO 


reservas[i].num avi — 0 
reservas[i].nome — “ 
FIM 
pos livre + 1 
REPITA 
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ESCREVA “Menu de Opções” 


ESCREVA “1 — Cadastrar os números dos aviões” 

ESCREVA “2 — Cadastrar os lugares disponíveis em cada avião” 
ESCREVA “3 — Reservar passagem” 

ESCREVA “4 — Consultar pelo número do avião” 

ESCREVA “5 — Consultar pelo nome do passageiro” 

ESCREVA “6 — Finalizar” 

ESCREVA “Digite a opção desejada” 

LEIA op 

SE op = 1 


ENTÃO INÍCIO 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
ESCREVA “Digite o número do “, i, “º avião” 
LEIA avi[i] 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
PARA i — 1 ATÉ 4 FAÇA 


INÍCIO 
ESCREVA “Digite o número de lugares disponíveis no “, i, “º 
LEIA lug[i] 

FIM 


FIM 
SE op = 3 
ENTÃO INÍCIO 
ESCREVA “Digite o número do avião no qual deseja efetuar a reserva” 
LEIA numero 
SE pos livre > 60 
ENTÃO ESCREVA “Reservas em todos os aviões esgotadas” 
SENÃO INÍCIO 
achou + 0 
PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
SE avi[i] = numero 
ENTÃO INÍCIO 
achou — 1 
posi — i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Este avião não existe” 
SENÃO SE lug[posi] = 0 
ENTÃO ESCREVA “Avião lotado" 
SENÃO INÍCIO 


avião” 


ESCREVA “Digite o nome do passageiro” 


LEIA nome 


reservas[pos_livre].num avi + numero 


reservas[pos_livre].nome + nome 


ESCREVA “Reserva efetuada com sucesso” 


pos livre + pos livre + 1 
lug[posi] — lug[posi] - 1 
FIM 
FIM 
FIM 
SE op = 4 
ENTÃO INÍCIO 

ESCREVA “Digite o número do avião para consultar as reservas” 

LEIA numero 

achou — 0 
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PARA i — 1 ATÉ 4 FAÇA 
INÍCIO 
SE avi[i] = numero 
ENTÃO achou — 1 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Este avião não existe ” 
SENÃO INÍCIO 
achou + 0 
PARA i — 1 ATÉ (pos_livre — 1) FAÇA 
INÍCIO 
SE reservas[i].num avi = numero 
ENTÃO INÍCIO 
ESCREVA reservas[i].nome 
achou + 1 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhuma reserva está cadastrada para este avião” 
FIM 
FIM 
SE op = 5 
ENTÃO INÍCIO 
ESCREVA “Digite o nome do passageiro para consultar as reservas” 
LEIA nome 
achou + 0 
PARA i — 1 ATÉ (pos livre — 1) FAÇA 
INÍCIO 
SE reservas[i].nome = nome 
ENTÃO INÍCIO 
ESCREVA reservas[iJ].num avi 
achou + 1 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhuma reserva está cadastrada para este nome” 
FIM 
ATÉ op = 6 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
GEE NEXERCACAP10NPASCALNEX4.PAS e \EXERC\CAP10\PASCAL\EX4. EXE 


C/C++ Solução: 
E \EXERC\CAP10\C++\EX4.CPP e \EXERC\CAP10\C++\EX4. EXE 


BAIANO SOLUÇÃO: 
E VEXERCACAP10NJAVANEX4. java e NEXERCACAPIONJAVANEX4.class 


EA Uma empresa possui 18 funcionários, sobre os quais se tem estas informações: nome, número de horas 
trabalhadas no mês, turno de trabalho (pode ser M — matutino; V — vespertino; ou N — noturno), 
categoria (pode ser O — operário; ou G — gerente) e valor da hora trabalhada. Sabendo-se que essa 
empresa deseja informatizar sua folha de pagamento, faça um programa que leia o nome, o número de 
horas trabalhadas no mês, o turno e a categoria dos funcionários, não permitindo que sejam informa- 
dos turnos e categorias inexistentes. O programa deverá calcular o valor da hora trabalhada, conforme 
a tabela a seguir, adotando o valor de R$ 550,00 para o salário-mínimo. 
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Categoria Turno Valor da hora trabalhada 
G N 18% do salário-mínimo 
G M ou V 15% do salário-mínimo 
(0) N 13% do salário-mínimo 
O M ou V 10% do salário-mínimo 


O programa deverá calcular o salário inicial dos funcionários, com base no valor da hora e no número 
de horas trabalhadas. Todos recebem um auxílio-alimentação, de acordo com o seu salário inicial, confor- 
me a tabela a seguir. 


Salário inicial Auxílio-alimentação 
< R$ 550,00 20% do salário inicial 
> R$ 550,00 e < R$ 800,00 15% do salário inicia 
= R$ 800,00 5% do salário inicial 


O programa deverá mostrar o nome, o número de horas trabalhadas, o valor da hora trabalhada, o 
salário inicial, o auxílio-alimentação e o salário final (salário inicial + auxílio-alimentação) de todos os fun- 
cionários. Ele deverá apresentar o seguinte menu de opções: 

1. Cadastrar funcionários. 

2. Mostrar folha de pagamento. 

3. Sair. 


(ALLTSIOJRNTTIMO) Solução: 


ALGORITMO 
DECLARE func[18] REGISTRO (num horas trab, valor hora NUMÉRICO, 
nome, turno, cat LITERAL) 
i, pos livre, op, sal minimo, sal inicial, aux alim, sal final NUMÉRICO 
PARA i — 1 ATÉ 18 FAÇA 
INÍCIO 
func[i].num horas trab + 0 
func[i].valor hora + 0 
func[i].nome — “ 
func[i].turno — ” 
func[i].cat — ” 


FIM 
pos livre — 1 
REPITA 
ESCREVA “Menu de Opções” 
ESCREVA “1 — Cadastrar funcionários” 
ESCREVA “2 — Mostrar folha de pagamento” 
ESCREVA “3 — Sair” 
ESCREVA “Digite a opção desejada” 
LEIA op 


Sm lj) <S df A go) > is 
ENTÃO ESCREVA “Opção Inválida” 
SE op = 1 
ENTÃO INÍCIO 
SE pos_livre > 18 
ENTÃO ESCREVA “Cadastro de funcionários lotado" 
SENÃO INÍCIO 
sal_minimo + 550 
ESCREVA “Digite o nome do funcionário que deseja incluir” 
LEIA func[pos_livre].nome 
ESCREVA “Digite o número de horas trabalhadas” 
LEIA func[pos_livre].num horas_trab 
ESCREVA “Digite o turno de trabalho” 
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REPITA 
LEIA func[pos livre].turno 
ATÉ func[pos livre].turno = “M” OU func[pos livre].turno= “v” OU 
= func[pos livre].turno = “N” 
ESCREVA “Digite a categoria” 
REPITA 
LEIA func[pos livre].cat 
ATÉ func[pos livre].cat = “O” OU func[pos livre].cat = “G” 
SE func[pos livre].cat = “G” 
ENTÃO SE func[pos livre].turno = “N” 
ENTÃO func[pos livre].valor hora <— sal minimo * 18/100 
SENÃO func[pos livre].valor hora + sal minimo * 15/100 
SE func[pos livre].cat = “0” 
ENTÃO SE func[pos livre].turno = “N” 
ENTÃO func[pos livre].valor hora — sal minimo * 13/100 
SENÃO func[pos livre].valor hora + sal minimo * 10/100 
ESCREVA “Funcionário cadastrado com sucesso” 
pos livre « pos livre + 1 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
ESCREVA “Folha de Pagamento” 
SE pos livre = 1 
ENTÃO ESCREVA “Não existe funcionário cadastrado” 
SENÃO INÍCIO 
PARA i < 1 ATÉ (pos livre — 1) FAÇA 
INÍCIO 
ESCREVA func[i].nome, func[i].num horas trab, func[i].valor hora 
sal inicial + func[i].num horas trab * func[i].valor hora 
ESCREVA sal inicial 
SE sal inicial < 550 
ENTÃO aux alim + sal inicial * 20/100 
SENÃO SE sal inicial < 800 
ENTÃO aux alim — sal inicial * 15/100 
SENÃO aux alim — sal inicial * 5/100 
ESCREVA aux alim 
sal final « sal inicial + aux alim 
ESCREVA sal final 
FIM 
FIM 
FIM 
ATÉ op = 3 
FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 
GEES VEXERCACAP10NPASCALVEX5.PAS e \EXERC\CAP10\PASCAL\EX5.EXE 


eylen Ra SoLução: 
D \EXERC\CAP10\C++\EX5.CPP e \EXERC\CAP10\C++\EX5.EXE 


RB WIAN Solução: 
cs VEXERCACAP10ONJAVANEX5. java e NEXERCACAPIONJAVANEX5.class 


EA Uma empresa contratou 15 funcionários temporários. De acordo com o valor das vendas mensais, os 
funcionários ganham pontos que determinarão seus salários ao fim de cada mês. Sabe-se que eles tra- 
balharão nos meses de novembro de 2011 a janeiro de 2012. Faça um programa que: 

a) Cadastre os nomes dos funcionários e suas respectivas vendas mensais. 


b) Calcule e mostre a pontuação geral de cada funcionário nos três meses. Sabe-se que R$ 100,00 equivalem a 
1 ponto. 
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c) Calcule e mostre a pontuação geral de todos os funcionários a cada mês. 

d) Determine e mostre a maior pontuação atingida nos três meses, mostrando o nome do funcionário. Deverão 
ser desconsiderados empates. 

e) Determine e mostre o valor total vendido. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE func[15] REGISTRO (nome LITERAL, venda nov, venda dez, venda jan NUMÉRICO) 
i, pontos, maior, pos maior, mes, valor total NUMÉRICO 
ESCREVA “CADASTRANDO OS FUNCIONÁRIOS” 
PARA i « 1 ATÉ 15 FAÇA 
INÍCIO 

ESCREVA “Digite o nome do “,i, ” 2 funcionário” 
LEIA func[i].nome 


ESCREVA “Digite o valor vendido no mês de novembro pelo “,i, “ º funcionário” 
LEIA func[i].venda nov 
ESCREVA “Digite o valor vendido no mês de dezembro pelo “,i, ” º funcionário” 
LEIA func[i].venda dez 
ESCREVA “Digite o valor vendido no mês de janeiro pelo “,i, “ º funcionário” 
LEIA func[i].venda jan 

FIM 

ESCREVA “MOSTRANDO AS PONTUAÇÕES MENSAIS DE CADA FUNCIONÁRIO” 
PARA i « 1 ATÉ 15 FAÇA 

INÍCIO 
ESCREVA “Funcionário: ”, func[i].nome 
pontos <- func[i].venda nov/100 
ESCREVA “Pontos de novembro = ”, pontos 
pontos +- func[i].venda dez/100 
ESCREVA “Pontos de dezembro = ”, pontos 
pontos <- func[i].venda jan/100 
ESCREVA “Pontos de janeiro = *“, pontos 
pontos +- func[i].venda nov/100 + func[i].venda dez/100 + func[i].venda jan/100 
ESCREVA “Total de pontos = ”, pontos 

FIM 


ESCREVA “MOSTRANDO A PONTUAÇÃO TOTAL DO MÊS DE NOVEMBRO” 
pontos + 0 
PARA i + 1 ATÉ 15 FAÇA INÍCIO 

pontos +- pontos + func[i].venda_nov/100 
FIM 
ESCREVA pontos 
ESCREVA “MOSTRANDO A PONTUAÇÃO TOTAL DO MÊS DE DEZEMBRO” 
pontos + 0 
PARA i « 1 ATÉ 15 FAÇA INÍCIO 

pontos + pontos + func[i].venda dez/100 
FIM 
ESCREVA pontos 
ESCREVA “MOSTRANDO A PONTUAÇÃO TOTAL DO MÊS DE JANEIRO” 
pontos + 0 
PARA i - 1 ATÉ 15 FAÇA 

INÍCIO 

pontos +- pontos + func[i].venda_jan/100 

FIM 
ESCREVA pontos 
ESCREVA “MOSTRANDO A MAIOR PONTUAÇÃO” 
maior < 0 
PARA i +- 1 ATÉ 15 FAÇA 

INÍCIO 

SE func[i].venda_nov/100 > maior 
ENTÃO INÍCIO 
maior +- func[i].venda_nov/100 
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pos maior + i 
mes + 1 
FIM 
SE func[i].venda dez/100 > maior 
ENTÃO INÍCIO 
maior « func[i].venda dez/100 
pos maior + i 
mes + 2 
FIM 
SE func[i].venda_jan/100 > maior 
ENTÃO INÍCIO 
maior +- func[i].venda_jan/100 
pos maior + i 


mes +- 3 
FIM 

FIM 
ESCREVA “Funcionário: “,  func[pos maior].nome 
ESCREVA “Maior pontuação: “, maior 
SE mes = 1 

ENTÃO ESCREVA “No mês de novembro” 
SE mes = 2 

ENTÃO ESCREVA “No mês de dezembro” 
SE mes = 3 


ENTÃO ESCREVA “No mês de janeiro” 
ESCREVA “MOSTRANDO O VALOR TOTAL VENDIDO” 
pontos <- 0 
PARA i +- 1 ATÉ 15 FAÇA 


INÍCIO 
pontos < pontos + func[i].venda nov + func[i].venda_dez + func[i]. venda jan 
FIM 
ESCREVA “Total vendido = “, pontos 


FIM ALGORITMO. 


INST OH SOLUÇÃO: 
Ee VEXERCACAP10NPASCALVEX6.PAS e \EXERC\CAP10\PASCAL\EX6.EXE 


eylen Ra Sorução: 
Gi \EXERC\CAP10\C++\EX6.CPP e NEXERCACAP1IONC++NEX6. EXE 


RB WIA NA SoLução: 
(ERR VEXERCACAPIONJAVANEX6.java e NEXERCICAPIONJAVANEX6.class 


IEA Crie um programa para ler o código, o sexo (M — masculino; F — feminino) e o número de horas- 
-aula ministradas pelos professores de uma escola durante um mês. Sabe-se que um professor ganha 
R$ 60,50 hora-aula e que a escola possui dez professores. Após a leitura, o programa deverá mostrar: 
a 


) 
b) A média aritmética dos salários brutos dos professores do sexo masculino. 
c) A média aritmética dos salários brutos dos professores do sexo feminino. 
Os descontos devem ser assim calculados: 


Uma listagem contendo o código, o salário bruto, o desconto e o salário líquido de todos o professores. 


Sexo Até 70 horas/aula ao mês Mais que 70 horas/aula ao mês 
Masculino 10% 8% 


Feminino 7% 5% 
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(AILIGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE prof[10] REGISTRO (cod, num aula UMÉRICO, sexo LITERAL) 
i, sal bruto, desc, sal liq, ma masc, ma fem NUMÉRICO 
soma masc, soma fem, qt masc, qt fem NUMÉRICO 
soma masc + 0 
soma fem < 0 
qt masc -0 
qt fem O 
ESCREVA “Digitando os dados dos 10 professores” 
PARA i «< 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA i, “ o professor” 
ESCREVA “Digite o código” 
LEIA prof[i].cod 
ESCREVA “Digite o número de aulas” 
LEIA prof[i].num aula 
ESCREVA “Digite o sexo” 
LEIA prof[i].sexo 
FIM 
ESCREVA “Mostrando a listagem com os salários dos professores” 
PARA i — 1 ATÉ 10 FAÇA 
INÍCIO 
ESCREVA prof[i].cod 
sal bruto + 60.50 * prof[iJ].num aula 
ESCREVA sal bruto 
SE prof[i].sexo = “F” 
ENTÃO INÍCIO 
SE prof[i].num aula < 70 
ENTÃO desc + sal bruto * 7/100 
SENÃO desc + sal bruto * 5/100 
FIM 
SENÃO INÍCIO 
SE prof[i].num aula < 70 
ENTÃO desc + sal bruto * 10/100 
SENÃO desc + sal bruto * 8/100 
FIM 
ESCREVA desc 
sal ligq +- sal bruto — desc 
ESCREVA sal liqg 
SE prof[i].sexo = “F” 
ENTÃO INÍCIO 
soma fem +- soma fem + sal bruto 
(ane ES < roter Sue ao dl 
FIM 
SENÃO INÍCIO 
soma masc +- soma masc + sal bruto 
qt masc + qt masc + 1 
FIM 
FIM 
SE qt fem = 0 
ENTÃO ma fem — 0 
SENÃO ma fem < soma fem / gt fem 
SE qt masc = 0 
ENTÃO ma masc — 0 
SENÃO ma masc < soma masc / qt masc 
ESCREVA “Média dos salários brutos dos professores do sexo feminino = “,ma fem 
ESCREVA “Média dos salários brutos dos professores do sexo masculino = “,ma masc 
FIM ALGORITMO. 
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PASCAL SOLUÇÃO: 


VEXERCACAP1IONPASCALNEX7.PAS e NEXERCACAP10ONPASCALNEX7.EXE 


(S 
eyler Ra SoLuçÃo: 
C \EXERC\CAP10\C++\EX7.CPP e \EXERC\CAP10\C++\EX7.EXE 


RB WIAN Solução: 


(RE VEXERCACAPIONJAVANEX7.java e NEXERCICAPIONJAVANEX7.class 


EJ Veja os campos de alguns registros: 
Professor (número de registro, nome, cod título, total h/a semanal) 
Título (cod título, descrição, valor hora/aula) 
Elabore um programa que: 
Crie uma rotina para cadastrar os títulos. Sabe-se que nessa escola existem cinco títulos. 


Crie uma rotina para cadastrar os professores. Sabe-se que nessa escola trabalham 14 professores, 
e cada um deve estar associado a um título previamente cadastrado. 


Crie uma rotina para mostrar a relação de professores, conforme o layout a seguir. 


Nº do registro Nome Título (descrição) Valor hora/ aula Total H/A Total geral 
11 João da Silva | Mestre R$ 60,50 10 R$ 605,00 
113 Maria Oliveira | Especialista R$ 40,00 8 R$ 320,00 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 


DECLARE prof[14] REGISTRO (reg, cod titulo, total semanal NUMÉRICO, nome LITERAL) 
titulo[5] REGISTRO (cod titulo, valor NUMÉRICO, desc LITERAL) 
i, j, total geral, achou NUMÉRICO 

ESCREVA “Cadastrando os 5 títulos” 

PARA j e 1 ATÉ 5 FAÇA 


INÍCIO 

ESCREVA “Digite o código do “, j , “2 título: “ 
LEIA titulo[j].cod titulo 
ESCREVA “Digite a descrição do “, j , “ 2 título: “” 
LEIA titulo[j].desc 
ESCREVA “Digite o valor da hora aula do “, j , “e título: “ 
LEIA titulo[j].valor 

FIM 


ESCREVA “Cadastrando os 14 professores” 
PARA i « 1 ATÉ 14 FAÇA 
INÍCIO 
ESCREVA “Digite o registro do “, i 
LEIA prof[il].reg 
ESCREVA “Digite o título do “, i , “º professor: ” 
LEIA prof[i].cod titulo 
achou + 0 
ENQUANTO achou = 0 FAÇA 
INÍCIO 
PARA j « 1 ATÉ 5 FAÇA 
INÍCIO 
SE titulo[j].cod_titulo = prof[i].cod titulo 
ENTÃO achou © 1 


“2 professor: “ 


FIM 
SE achou = 0 
ENTÃO INÍCIO 


ESCREVA “Título não cadastrado, digite novo título: “ 
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LEIA prof[i].cod titulo 
FIM 
FIM 
ESCREVA “Digite a carga horária semanal do “, i , “º professor: ” 
LEIA prof[i].total semanal 
ESCREVA “Digite o nome do “, i , “ professor: “ 
LEIA prof[i].nome 
FIM 
ESCREVA “Mostrando a relação de professores” 
PARA i +- 1 ATÉ 14 FAÇA 
INÍCIO 
ESCREVA prof[i].reg, prof[i].nome 
PARA j « 1 ATÉ 5 FAÇA 
INÍCIO 
SE prof[i].cod titulo = titulo[j].cod titulo 
ENTÃO INÍCIO 
ESCREVA titulo[j].desc, titulo[j].valor 
total geral +- titulo[j].valor * prof[i].total semanal 
ESCREVA prof[i].total semanal, total geral 
FIM 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL, SOLUÇÃO: 
oe \EXERC\CAP10\PASCAL\EX8.PAS e \EXERC\CAP10\PASCAL\EX8.EXE 


LETTA SoLução: 
Ea \EXERC\CAP10\C++\EX8.CPP e \EXERC\CAP10\C++\EX8. EXE 


RR WIA NA SoLução: 
GEE VEXERCÍCAP10ONJAVANEX8. java e NEXERCACAPIONJAVANEX8.class 


BEAR Crie um pequeno sistema para controle automatizado de estoque com os seguintes registros: 


Clientes Notas Itens notas Produtos 
Cod cliente Numero. NF Numero. NF Cod produto 
Endereco Cod cliente Cod produto Descricao 
Telefone Total geral Quantidade Unidade 

Preco venda Preco unitario 


Qtdade estoque 


O sistema deverá conter os seguintes módulos: CADASTROS, MOVIMENTAÇÕES, CONSULTAS, 
além de uma opção para SAÍDA. 


1. O módulo CADASTROS deverá fazer a manutenção das informações sobre clientes e produtos (seis 
produtos e três clientes): 

a) Manutenção de CLIENTES — inclusão, tomando cuidado para não cadastrar dois clientes com o mesmo 
código; alteração, o único campo que não pode ser alterado é o código; exclusão, tomando cuidado para não 
permitir a exclusão de clientes que possuam nota fiscal. 

b) Manutenção de PRODUTOS — inclusão, tomando cuidado para não cadastrar dois produtos com o mesmo 
código; alteração, o único campo que não pode ser alterado é o código; exclusão, tomando cuidado para não 
permitir a exclusão de produtos pertencentes a alguma nota fiscal. 

2. O módulo MOVIMENTAÇÕES deverá permitir a digitação de notas fiscais de saída, de acordo com as espe- 
cificações a seguir, supondo que poderão ser gravadas até cinco notas fiscais contendo dois itens em cada uma: 
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a) Não cadastrar duas notas com o mesmo número. 


b) Uma nota só pode ser emitida a um cliente que já exista. 
c) Todos os produtos da nota devem estar previamente cadastrados; caso contrário, emitir mensagem de erro. 
d) Não cadastrar duas vezes um produto na mesma nota. 


Quando um produto for confirmado, baixar sua quantidade em estoque e gravar um registro em ITENS NO- 
TAS. 

O módulo CONSULTAS deverá permitir as consultas descritas a seguir: 

a) Todos os produtos com preços entre dois valores digitados pelo usuário. 

b) Todas as notas e os itens da nota de um cliente escolhido pelo usuário. 


e 


c) Todas as notas e os itens da nota com total geral superior a um valor escolhido pelo usuário. 


(AILISIOJRN ITIMO) Solução: 


ALGORITMO 

DECLARE cliente[3] REGISTRO (cod cliente NUMÉRICO, ende, fone LITERAL) 
produto[6] REGISTRO (cod produto, preco unit, qtde est NUMÉRICO, desc, unid 
LITERAL) 
nota[5] REGISTRO (numero_nf, cod cliente, total NUMÉRICO) 
itens_nota[10] REGISTRO (numero_nf, cod_prod, qtde, preco vend NUMÉRICO) 
i, j, k, h, cont, achou, opl, op2, posi, codigo_cli NUMÉRICO 
livre_cliente, livre_produto, livre_nota NUMÉRICO 
livre_item, codigo, pre, qtde NUMÉRICO 
valor, valor inicial, valor final NUMÉRICO 
endere, telefone, desc, unidade, resp LITERAL 

livre cliente + 1 

livre produto — 1 

livre nota — 1 

livre item — 1 


REPITA 

ESCREVA “Menu de Opções” 

ESCREVA “1 — Cadastros” 

ESCREVA “2 — Movimentações” 

ESCREVA “3 — Consultas” 

ESCREVA “4 — Sair” 

ESCREVA “Digite sua opção” 

LEIA opl 

SE opl < 1 OU opl > 4 
ENTÃO ESCREVA “Opção inválida, digite novamente” 
SE opl = 1 
ENTÃO 
INÍCIO 
REPITA 

ESCREVA “Sub-menu de Opções” 
ESCREVA “1 - Incluir clientes” 
ESCREVA “2 - Alterar clientes” 
ESCREVA “3 - Excluir clientes” 
ESCREVA “4 - Incluir produtos” 
ESCREVA “5 - Alterar produtos” 
ESCREVA “6 - Excluir produtos” 
ESCREVA “7 - Sair” 
ESCREVA “Digite sua opção” 
LEIA op2 


SE op2 < 1 OU op2 > 7 
ENTÃO ESCREVA “Opção inválida, digite novamente” 
SE op2 1 
ENTÃO 
INÍCIO 
ESCREVA “Inclusão de Clientes” 
SE livre cliente 4 
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ENTÃO ESCREVA “Cadastro de clientes lotado” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do cliente a ser incluído” 
LEIA código 
achou — 0 
PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 
SE cliente[i].cod cliente = codigo 
ENTÃO achou + 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Já existe cliente com este código” 
SENÃO 
INÍCIO 
ESCREVA “Digite o endereço do cliente” 
LEIA endere 
ESCREVA “Digite o telefone do cliente” 
LEIA telefone 
cliente[livre cliente].cod cliente < código 
cliente[livre cliente].ende < endere 
cliente[livre cliente].fone - telefone 
ESCREVA “Cliente cadastrado com sucesso!” 
livre cliente — livre cliente + 1 


FIM 
FIM 
FIM 
SE op2 = 2 
ENTÃO 
INÍCIO 


ESCREVA “Alteração de Clientes” 
SE livre cliente = 1 
ENTÃO ESCREVA “Cadastro de clientes vazio” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do cliente a ser alterado” 
LEIA código 
achou « 0 
PARA i + 1 ATÉ 3 FAÇA 
INÍCIO 
SE cliente[i].cod cliente = código 
ENTÃO 
INÍCIO 
achou « 1 
posi « i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe cliente com esse código” 
SENÃO 
INÍCIO 
ESCREVA “Digite o novo endereço do cliente” 
LEIA endere 
ESCREVA “Digite o novo telefone do cliente” 
LEIA telefone 
cliente[posi].ende — endere 
cliente[posi].fone — telefone 
ESCREVA “Cliente alterado com sucesso!” 
FIM 
FIM 
FIM 
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SE op2 = 3 
ENTÃO 
INÍCIO 
ESCREVA “Exclusão de Clientes” 
SE livre cliente = 1 
ENTÃO ESCREVA “Cadastro de clientes vazio” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do cliente a ser excluído” 
LEIA código 
achou + 0 
PARA i — 1 ATÉ 3 FAÇA 
INÍCIO 
SE cliente[i].cod cliente = codigo 
ENTÃO 
INÍCIO 
achou — 1 
posi — i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe cliente com este código” 
SENÃO 
INÍCIO 
achou — 0 
PARA j — 1 ATÉ (livre nota - 1) FAÇA 
INÍCIO 
SE nota[j].cod cliente = codigo 
ENTÃO achou + 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Cliente possui notas. Não pode ser excluído.” 
SENÃO 
INÍCIO 
PARA j — posi ATÉ (livre cliente-2)FAÇA 
INÍCIO 
cliente[j].cod cliente — cliente[j+l].cod cliente 
cliente[j].ende — cliente[j+1].ende 
cliente[j].fone — cliente[j+1].fone 


FIM 
ESCREVA “Cliente excluído com sucesso!” 
livre cliente — livre cliente — 1 
FIM 
FIM 
FIM 
FIM 
SE op2 = 4 
ENTÃO 
INÍCIO 


ESCREVA “Inclusão de Produtos” 
SE livre produto = 7 
ENTÃO ESCREVA “Cadastro de produtos lotado” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do produto a ser incluído” 
LEIA código 
achou — 0 
PARA i — 1 ATÉ 6 FAÇA 
INÍCIO 
SE produto[i].cod produto = código 
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ENTÃO achou + 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Já existe produto com este código” 
SENÃO 
INÍCIO 
ESCREVA “Digite a descrição do produto” 
LEIA desc 
ESCREVA “Digite a unidade do produto” 
LEIA unidade 
ESCREVA “Digite o preço unitário do produto” 


LEIA pre 
ESCREVA “Digite a quantidade em estoque do produto” 
LEIA qtde 


produto[ livre produto].cod produto + código 
produto[ livre produto].desc — desc 
produto[ livre produto] .unid — unidade 
produto[ livre produto].preco unit — pre 
produto[ livre produto].qgtde est — qtde 
ESCREVA “Produto cadastrado com sucesso!” 
livre produto + livre produto + 1 
FIM 


FIM 
SE op2 = 5 
ENTÃO 
INÍCIO 
ESCREVA “Alteração de produtos” 
SE livre produto = 1 
ENTÃO ESCREVA “Cadastro de produtos vazio” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do produto a ser alterado” 
LEIA código 
achou — 0 
PARA i — 1 ATÉ 6 FAÇA 
INÍCIO 
SE produto[i].cod produto = código 
ENTÃO 
INÍCIO 
achou — 1 
posi — i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe produto com este código” 


SENÃO 
INÍCIO 
ESCREVA “Digite a nova descrição do produto” 
LEIA desc 


ESCREVA “Digite a nova unidade do produto” 
LEIA unidade 
ESCREVA “Digite o novo preço unitário” 


LEIA pre 
ESCREVA “Digite a nova quantidade em estoque” 
LEIA qtde 


produto[ livre produto].desc — desc 
produto[ livre produto].unid — unidade 
produto[ livre produto].preco unit — pre 
produto[ livre produto].qgtde est — qtde 
ESCREVA “Produto alterado com sucesso!” 
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FIM 
SE op2 = 6 
ENTÃO 
INÍCIO 
ESCREVA “Exclusão de produtos” 
SE livre produto = 1 
ENTÃO ESCREVA “Cadastro de produtos vazio” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do produto a ser excluído” 
LEIA código 
achou — 0 
PARA i — 1 ATÉ 6 FAÇA 
INÍCIO 
SE produto[i].cod produto = código 
ENTÃO 
INÍCIO 
achou — 1 
posi — i 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Não existe produto com este código” 
SENÃO 
INÍCIO 
achou — 0 
PARA j — 1 ATÉ (livre item — 1) FAÇA 
INÍCIO 
SE itens nota[j].cod prod = codigo 
ENTÃO achou + 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Não pode excluir produto. Faz parte de alguma nota” 
SENÃO 
INÍCIO 
PARA j—posi ATÉ (livre produto - 2) FAÇA 
INÍCIO 
produto[j].cod produto +— produto[j+1].cod produto 
produto[j].desc — produto[j+1].desc 
produto[j].unid — produto[j+1].unid 
produto[5].preco unit + produto[jt+1].preco unit 
produto[j].qgtde est — produto[jtl].qtde est 
FIM 
ESCREVA “Produto excluído com sucesso!” 
livre produto + livre produto — 1 


FIM 
FIM 
FIM 
FIM 
ATE q = 7 
FIM 
SE opl = 2 
ENTÃO 
INÍCIO 


ESCREVA “Cadastro de notas de saída” 
ESCREVA “Digite o número da nota” 
LEIA num_nota 

SE livre_nota = 6 

ENTÃO ESCREVA “Cadastro de notas lotado” 
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SENÃO 
INÍCIO 
achou — 0 
PARA i — 1 ATÉ livre nota - 1 FAÇA 
INÍCIO 
SE nota[iJ].numero nf = num nota 
ENTÃO achou — 1 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Já existe nota fiscal cadastrada com esse número” 
SENÃO 
INÍCIO 
ESCREVA “Digite o código do cliente” 
LEIA codigo cli 
achou — 0 
ENQUANTO achou = 0 FAÇA 
INÍCIO 
PARA i — 1 ATÉ livre cliente - 1 FAÇA 
INÍCIO 
SE cliente[i].cod cliente = codigo cli 
ENTÃO achou — 1 
FIM 
SE achou = 0 
ENTÃO 
INÍCIO 
ESCREVA “Este cliente não está cadastrado” 
ESCREVA “Digite outro cliente” 
LEIA codigo cli 
FIM 
FIM 
cont + 0 
Fesp sr 
ENQUANTO (cont < 2) E (resp = 's') FAÇA 
INÍCIO 
ESCREVA “Digite o código do produto” 
LEIA código 
achou — 0 
PARA k — 1 ATÉ livre produto - 1 FAÇA 
INÍCIO 
SE produto[k].cod produto = código 
ENTÃO 
INÍCIO 
SE produto[k].qgtde est = 0 
ENTÃO achou +- 2 
SENÃO 
INÍCIO 
achou — 1 
posi — k 
PARA h + 1 ATÉ livre_item - 1 FAÇA 
INÍCIO 
SE itens_nota[h].numero_nf = num_nota E 
itens_nota[h].cod_prod = código 
ENTÃO 
INÍCIO 
ESCREVA “Produto já existe nesta nota” 
achou — 0 
FIM 
FIM 
FIM 
FIM 
FIM 
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SE achou = 0 
ENTÃO 
INÍCIO 
ESCREVA “Este produto não está cadastrado” 
FIM 
SE achou = 2 
ENTÃO 
INÍCIO 
ESCREVA “Este produto está com estoque zerado” 
FIM 
SE achou = 1 
ENTÃO 
INÍCIO 
ESCREVA “Digite a quantidade” 
LEIA qtde 
ENQUANTO qtde > produto[posi].qgtde est FAÇA 
INÍCIO 
ESCREVA “Estoque insuficiente” 
ESCREVA “Digite outra quantidade” 
LEIA qtde 
FIM 
nota[livre nota].numero nf « num nota 
nota[livre nota].cod cliente — codigo cli 
nota[livre nota].total — nota[livre nota].total + (qtde * 
= produto[posi].preco unit) 
itens nota[livre item].numero nf « num nota 
itens nota[livre item].cod prod <— codigo 
itens nota[livre item].gtde — qtde 
itens nota[livre item].preco vend — qtde * produto[posi].preco unit 
livre item — livre item+ 1 
ESCREVA “Produto incluído na nota com sucesso!” 
produto[posi].qgtde est + produto[posi].gtde est - qtde 
cont «< cont + 1 
FIM 
SE cont < 2 
ENTÃO 
INÍCIO 
ESCREVA “Deseja cadastrar outro produto nesta nota?” 
ESCREVA “s - sim ou n — não” 
LEIA resp 
FIM 
FIM 
SE cont >= 1 
ENTÃO 
INÍCIO 
livre nota + livre nota + 1 


ESCREVA “Nota cadastrada com sucesso!” 
FIM 
FIM 
FIM 
FIM 
SE opl = 3 
ENTÃO 
INÍCIO 
REPITA 
ESCREVA “Submenu de opções” 
ESCREVA “1 - Consultar todos os produtos com preços entre dois valores” 
ESCREVA “2 - Consultar todas as notas de um cliente” 
ESCREVA “3 - Consultar todas as notas com total superior a um determinado valor” 
ESCREVA “4 - Sair “ 
ESCREVA “Digite sua opção” 
LEIA op2 
SE op2 < 1 OU op2 > 4 
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ENTÃO ESCREVA “Opção inválida, digite novamente” 
SE op2 = 1 
ENTÃO 
INÍCIO 
ESCREVA “Consultar todos os produtos com preços entre dois valores” 
ESCREVA “Digite o valor inicial” 
LEIA valor inicial 
ESCREVA “Digite o valor final” 
LEIA valor final 
SE livre produto = 1 
ENTÃO ESCREVA “Nenhum produto está cadastrado” 
SENÃO 
INÍCIO 
achou — 0 
PARA i — 1 ATÉ livre produto - 1 FAÇA 
INÍCIO 
SE produto[i].preco unit >= valor inicial E 
produto[i].preco unit <= valor final 
ENTÃO 
INÍCIO 
achou — 1 
ESCREVA produto[i].cod produto 
ESCREVA produto[i].desc 


FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhum produto foi cadastrado com estes preços” 
FIM 
FIM 
SE op2 = 2 
ENTÃO 
INÍCIO 


ESCREVA “Consultar todas as notas e itens da nota de um cliente” 
ESCREVA “Digite o código do cliente” 
LEIA código 
SE livre cliente = 1 
ENTÃO ESCREVA “Não existe cliente cadastrado” 
SENÃO 
INÍCIO 
achou — 0 
PARA i — 1 ATÉ livre cliente - 1 FAÇA 
INÍCIO 
SE cliente[i].cod cliente = codigo 
ENTÃO achou <— 1 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Este cliente não está cadastrado” 
SENÃO 
INÍCIO 
SE livre nota = 1 
ENTÃO ESCREVA “Nenhuma nota cadastrada” 
SENÃO 
INÍCIO 
achou — 0 
PARA i — 1 ATÉ livre nota - 1 FAÇA 
INÍCIO 
SE nota[i].cod cliente = codigo 
ENTÃO 
INÍCIO 
achou — 1 
ESCREVA nota[i].numero nf 
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ESCREVA nota[i].total 
PARA j — 1 ATÉ livre item - 1 FAÇA 
INÍCIO 
SE itens nota[j].numero nf = nota[i].numero nf 
ENTÃO 
INÍCIO 
ESCREVA itens nota[j].cod prod 
ESCREVA itens nota[j].qtde 
ESCREVA itens nota[j].preco vend 
FIM 
FIM 
FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhuma nota cadastrada” 
FIM 
FIM 
FIM 
FIM 
SE op2 = 3 
ENTÃO 
INÍCIO 
ESCREVA “Consultar todas as notas e itens da nota com total superior a um valor” 
ESCREVA “Digite o valor” 
LEIA valor 
SE livre nota = 1 
ENTÃO ESCREVA “Não existe nota cadastrada” 
SENÃO 
INÍCIO 
achou — 0 
PARA i — 1 ATÉ livre nota - 1 FAÇA 
INÍCIO 
SE nota[i].total > valor 
ENTÃO 
INÍCIO 
achou — 1 
ESCREVA nota[i].numero nf 
ESCREVA nota[i].total 
PARA j — 1 ATÉ livre item - 1 FAÇA 
INÍCIO 
SE itens nota[j].numero nf = nota[i].numero nf 
ENTÃO 
INÍCIO 
ESCREVA itens nota[j].cod prod 
ESCREVA itens nota[j].qgtde 
ESCREVA itens nota[j].preco vend 
FIM 


FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhuma nota cadastrada” 
FIM 
FIM 
ATÉ op2 = 4 
FIM 

ATÉ opl = 4 
FIM ALGORITMO. 
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PASCAL, [Sono to 
RE NEXERCACAP10NPASCALNEX9.PAS e VEXERCICAP1IONPASCALNEX9.EXE 


C/C++ Sorução: 
cus \EXERC\CAP10\C++\EX9.CPP e NEXERCACAPIONC++NEX9. EXE 


E-G- SoLução: 
D \EXERC\CAP10\JAVA\EX9.java e \EXERC\CAP10\JAVA\EX9.class 


HA Uma empresa do ramo de material esportivo deseja ter um controle automatizado dos funcionários 
que trabalham em cada uma de suas filiais. Sabe-se que essa empresa possui quatro filiais com quatro 
vendedores e um gerente em cada uma delas. Todos devem ser cadastrados como funcionários. 

Faça um programa que realize esse controle, com as seguintes rotinas: 

a) Cadastrar filial, observando que não podem existir duas filiais com o mesmo número. 

b) Cadastrar funcionário, observando que: 1) não podem existir dois funcionários com o mesmo número; 2) 
cada funcionário deve ser cadastrado em uma filial; e 3) cada filial pode ter apenas um gerente e no máximo 
quatro vendedores; 

c) Criar uma consulta a todas as filiais, mostrando o nome do gerente e dos vendedores, o valor total gasto com 
pagamento de salários por filial e o valor gasto com pagamento de salário geral. 


Filial Funcionário 
Numero. filial Numero. filial 
Nome filial Codigo funcionario 


Nome funcionario 
Cargo 
Salario 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE filial[4] REGISTRO (numero filial NUMÉRICO nome filial LITERAL) 
func[20] REGISTRO (numero filial, cod func, salario NUMÉRICO 
cargo, nome func LITERAL) 
i, j, livre filial, livre func NUMÉRICO total geral, total filial NUMÉRICO 
sal, cont, filial, op, achou, numero NUMÉRICO cargo, nome LITERAL 
iyreBsuncas ii 
livre filial — 1 
total geral — 0 
REPITA 
ESCREVA “Menu de Opções” 
ESCREVA “1 — Cadastrar filial” 
ESCREVA “2 — Cadastrar funcionário” 
ESCREVA “3 — Consultar filiais” 
ESCREVA “4 — Sair” 
ESCREVA “Digite a opção desejada” 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
ESCREVA “Cadastro de filiais” 
SE livre filial = 5 
ENTÃO ESCREVA “Cadastro de filiais lotado” 
SENÃO INÍCIO 
ESCREVA “Digite o número da filial” 
LEIA numero 
achou + 0 
PARA i < 1 ATÉ livre filial — 1 FAÇA 
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INÍCIO 
SE filial[i].numero filial = numero 
ENTÃO achou — 1 
FIM 
SE achou = 1 


ENTÃO ESCREVA “Já existe filial cadastrada com este número” 


SENÃO INÍCIO 
ESCREVA “Digite o nome da filial” 
LEIA nome 
filial[livre filial].numero filial « numero 
filial[livre filial].nome filial « nome 
ESCREVA “Filial cadastrada com sucesso!” 
livre filial «— livre filial + 1 
FIM 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
ESCREVA “Cadastro de funcionários” 
SE livre func = 21 
ENTÃO ESCREVA “Cadastro de funcionários lotado” 
SENÃO INÍCIO 
ESCREVA “Digite o número do funcionário a ser cadastrado” 
LEIA numero 
achou + 0 
PARA i + 1 ATÉ livre func — 1 FAÇA 


INÍCIO 
SE func[i].cod func = numero 
ENTÃO achou — 1 

FIM 


SE achou = 1 


ENTÃO ESCREVA “Já existe funcionário cadastrado com este código” 


SENÃO INÍCIO 


ESCREVA “Digite o número da filial deste funcionário” 


LEIA filial 
achou — 0 
PARA i — 1 ATÉ livre filial — 1 FAÇA 
INÍCIO 
SE filial[i].numero filial = filial 
ENTÃO achou — 1 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Esta filial não está cadastrada” 
SENÃO INÍCIO 
cont — 0 
PARA i + 1 ATÉ livre func — 1 FAÇA 
INÍCIO 
SE func[i].numero filial = filial 
ENTÃO cont + cont + 1 
FIM 
SE cont = 5 


ENTÃO ESCREVA “Esta filial está com todos os funcionários” 


SENÃO 
INÍCIO 


ESCREVA “Digite o cargo do funcionário” 


LEIA cargo 
SE cargo = “Gerente” 
ENTÃO 
INÍCIO 
cont + 0 


PARA i — 1 ATÉ livre func — 1 FAÇA 
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INÍCIO 
SE func[i].numero filial = filial E 
func[i].cargo = cargo 
ENTÃO cont — cont + 1 
FIM 
SE cont = 1 
ENTÃO ESCREVA “Filial já possui gerente” 
SENÃO cont — 0 
FIM 
SE cargo = “Vendedor” 
ENTÃO 
INÍCIO 
cont « 0 
PARA i — 1 ATÉ livre func — 1 FAÇA 
INÍCIO 
SE func[i].numero filial = filial E 
func[i].cargo = cargo 
ENTÃO cont — cont + 1 
FIM 
SE cont = 4 
ENTÃO ESCREVA “Filial já tem 4 vendedores” 
SENÃO cont — 0 
FIM 
SE cont = 0 
ENTÃO 
INÍCIO 
ESCREVA “Digite o salário” 
LEIA sal 
ESCREVA “Digite o nome do funcionário” 
LEIA nome 
func[livre func].numero filial + filial 
func[livre func].cod func + numero 
func[ livre func].salario — sal 
func[ livre func].cargo + cargo 
func[ livre func].nome func + nome 
ESCREVA “Funcionário cadastrado com sucesso!” 
livre func + livre func + 1 
FIM 


FIM 


FIM 
FIM 
SE op = 3 
ENTÃO INÍCIO 
SE livre filial = 1 
ENTÃO ESCREVA “Cadastro de filiais vazio” 
SENÃO SE livre func = 1 
ENTÃO ESCREVA “Cadastro de funcionários vazio” 
SENÃO INÍCIO 
PARA i + 1 ATÉ livre filial — 1 FAÇA 
INÍCIO 
ESCREVA “Número da filial: ”, filial[i].numero filial 
ESCREVA “Nome da filial: “, filial[i].nome filial 
total filial — 0 
PARA j — 1 ATÉ livre func — 1 FAÇA 
INÍCIO 
SE func[j].numero filial = filial[i].numero filial 
ENTÃO 
INÍCIO 
ESCREVA “Funcionário: ”, func[j].nome func 


Capítulo 10 Registro | 385 


ESCREVA “Cargo: ”, func[j].cargo 
total filial — total filial + func[j]. salario 
FIM 
FIM 
ESCREVA “Total de salário da filial = “, total filial 
total geral + total geral + total filial 
FIM 
ESCREVA “Total dos salários de todas as filiais = ”, total geral 
FIM 
FIM 
ATÉ op = 4 


FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
E \EXERC\CAP10\PASCAL\EX10.PAS e NEXERCACAPIONPASCALNEX10.EXE 


oPAeR Ra SoLução: 
GH \EXERC\CAP10\C++\EX10.CPP e NVEXERCACAP10NC++NEX10.EXE 


BAIA SOLUÇÃO: 
a! VEXERCACAP10NJAVANEX10. java e VEXERCACAP10NJAVANEX10.class 


EEB Crie um controle de matrícula anual de alunos em uma escola. Sabe-se que nessa escola é permitida a 
matrícula por disciplinas (o aluno monta seu horário). Esse controle deverá armazenar as informações 
pertinentes apenas a um ano. À escola oferece, a cada ano, seis disciplinas; sabe-se que existem dez 
alunos e que cada um pode matricular-se em, no máximo, três disciplinas a cada ano. 

As informações devem estar estruturadas conforme os registros a seguir: 


Aluno (código do aluno, nome do aluno, série). 
Matrícula (código do aluno, código da disciplina, total de faltas, nota final). 
Disciplina (código da disciplina, descrição, carga horária). 

O programa deverá seguir estas especificações: 
Cadastrar todas as disciplinas que poderão ser oferecidas no ano (não devem ser permitidas duas 
disciplinas com o mesmo código). 
Cadastrar alunos (não devem ser permitidos dois alunos com o mesmo código e os valores válidos 
para a série vão de 5 a 9). 
Realizar a matrícula do aluno (nesse momento, o aluno está apenas se inscrevendo na disciplina 
que ainda não foi cursada. Dessa maneira, os campos “total de faltas” e “nota final” não deverão ser 
preenchidos). 
Lançamento dos resultados finais (a secretaria, ao final do ano letivo, informa o código do aluno 
e o código da disciplina e preenche os campos “total de faltas” e “nota final” que estavam vazios). 
Criar uma consulta a todos os alunos reprovados nas disciplinas (a reprovação ocorrerá se a nota 
for menor que 7 ou se o total de faltas ultrapassar 25% da carga horária da disciplina). 


Criar uma rotina que mostre o nome das disciplinas cursadas por determinado aluno, junto com o 
total de faltas, a nota final e o resultado (aprovado ou reprovado). 


(AILTSIOJRN TTIMO) Solução: 


ALGORITMO 

DECLARE alunos[10] REGISTRO (cod a, serie NÚMERICO nome LITERAL) 
disciplinas[6] REGISTRO (cod d, carga hor NUMÉRICO descr LITERAL) 
matriculas[30] REGISTRO (cod a, cod d, faltas, nota NUMÉRICO) 
cont a, cont d, cont m, cont, alu aux, NUMÉRICO 
dis aux, achou, i, j, k, op, perc NUMÉRICO 


cont a < 1 
contadas 
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cont m <« 1 
REPITA 
ESCREVA “1l-Cadastrar disciplinas” 
ESCREVA “2-Cadastrar alunos” 
ESCREVA “3-Realizar matrículas” 
ESCREVA “4-Lançar notas e faltas” 
ESCREVA “5-Consultar alunos reprovados” 
ESCREVA “6-Mostrar disciplinas cursadas por aluno” 
ESCREVA “7-Finalizar” 
ESCREVA “Digite sua opção: “ 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
SE cont d <= 6 
ENTÃO INÍCIO 
LEIA dis aux 
i — 1 
ENQUANTO i < cont d E dis aux = disciplinas[i].cod_d FAÇA 
INÍCIO 
Leitar 
FIM 
SE i < cont d 
ENTÃO ESCREVA “Disciplina já cadastrada!” 
SENÃO INÍCIO 
disciplinas[cont d].cod d < dis aux 
LEIA disciplinas[cont d].descr 
LEIA disciplinas[cont d].carga hor 
contida contida! 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastradas as 6 disciplinas!” 
FIM 
SE op = 2 
ENTÃO INÍCIO 
SE cont a <= 10 
ENTÃO INÍCIO 
LEIA alu aux 


ie 1 
ENQUANTO i < cont a E alu aux = alunos[i].cod a FAÇA 
INÍCIO 
i—i+l 
FIM 


SE i < cont a 
ENTÃO ESCREVA “Aluno já cadastrado!” 
SENÃO INÍCIO 
alunos[cont a].cod a + alu aux 
LEIA alunos[cont a].nome 
REPITA 
LEIA alunos[cont a].serie 
ATÉ alunos[cont a].serie >= 5 E alunos[cont a].serie <= 9 
cont a < conta + 1 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastrados os 10 alunos!” 
FIM 
SE op = 3 
ENTÃO INÍCIO 
SE cont m <= 30 
ENTÃO INÍCIO 
LEIA alu aux 
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i — 1 
ENQUANTO i < cont a E alunos[i].cod_a = alu aux FAÇA 
INÍCIO 
+= dd 1 
FIM 
SE i = cont a 
ENTÃO ESCREVA “Aluno não cadastrado!” 
SENÃO INÍCIO 
cont — 0 
PARA i < 1 ATÉ cont m - 1 FAÇA 
INÍCIO 
SE matriculas[i].cod a = alu aux 
ENTÃO cont +- cont + 1 
FIM 
SE cont >= 3 
ENTÃO ESCREVA “Aluno já matriculado em 3 disciplinas” 
SENÃO 
INÍCIO 
LEIA dis aux 
j<- 1 
ENQUANTO j < cont d E disciplinas[j].cod d +dis_aux FAÇA 
INÍCIO 
qe apoqe dl 
FIM 
SE j = cont d 
ENTÃO INÍCIO 
ESCREVA “Disciplina não cadastrada!” 
achou + 1 
FIM 
SENÃO INÍCIO 
j — 1 
achou + 0 
ENQUANTO j < cont_m E achou = 0 FAÇA 
INÍCIO 
SE matriculas[j].cod_a = alu_aux E 
matriculas[j].cod_d = dis_aux 
ENTÃO achou ©- 1 
Jez 
FIM 
SE achou = 1 
ENTÃO ESCREVA “Aluno já matriculado nesta disciplina” 
SENÃO INÍCIO 
matriculas[cont_m].cod_a + alu aux 
matriculas[cont_m].cod_d <— dis aux 
matriculas[cont m].faltas — 0 
matriculas[cont mj.nota < 0 
cont m = cont m + 1 
FIM 
FIM 
FIM 
FIM 
FIM 
SENÃO ESCREVA “Não existe espaço para mais matrículas!” 
FIM 
SE op = 4 
ENTÃO INÍCIO 
LEIA alu aux 


i — 1 


388 | Fundamentos da programação de computadores 


ENQUANTO i < cont a E alunos[i].cod a * alu aux FAÇA 
INÍCIO 
i i+1 
FIM 
SE i = cont_a 
ENTÃO ESCREVA “Não existe aluno com este código!" 
SENÃO INÍCIO 
LEIA dis_aux 
i — 1 
ENQUANTO i < cont d E disciplinas[i].cod_d # dis aux FAÇA 
INÍCIO 
i i+l 
FIM 
SE i = cont d 
ENTÃO ESCREVA “Não existe disciplina com este código!” 
SENÃO INÍCIO 
i — 1 
ENQUANTO i < cont m E (matriculas[i].cod a = alu aux OU 
= matriculas[i].cod_d # dis aux) FAÇA 
INÍCIO 
e l 
FIM 
SE i = cont_m 
ENTÃO ESCREVA “Matrícula inválida!” 
SENÃO INÍCIO 
LEIA matriculas[i].faltas 
LEIA matriculas[i].nota 
FIM 
FIM 
FIM 
FIM 
SE op = 5 
ENTÃO INÍCIO 
PARA i < 1 ATÉ cont m - 1 FAÇA 


INÍCIO 
j e 1 
ENQUANTO j < cont d E matriculas[i].cod d + disciplinas[j]. cod d FAÇA 
INÍCIO 
j= j+1 
FIM 


perc + disciplinas[j].carga_hor * 25 / 100 
SE matriculas[i].faltas > perc OU matriculas[i].nota < 7 
ENTÃO 
INÍCIO 
k — 1 
ENQUANTO k < cont a E matriculas[i].cod_a * alunos[k].cod a FAÇA 
INÍCIO 
ko k+1 
FIM 
ESCREVA alunos[k].nome 
ESCREVA disciplinas[j].descr 
ESCREVA matriculas[i].faltas 
ESCREVA matriculas[i].nota 
FIM 
FIM 
FIM 
SE op = 6 
ENTÃO INÍCIO 
LEIA alu aux 
i — 1 
ENQUANTO i < cont a E alunos[i].cod_a # alu aux FAÇA 
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INÍCIO 
Le at 
FIM 
SE i = cont_a 
ENTÃO ESCREVA “Este aluno não está cadastrado!” 
SENÃO INÍCIO 
ESCREVA alunos[i].nome 
PARA i < 1 ATÉ cont m - 1 FAÇA 
INÍCIO 
SE matriculas[i].cod a = alu aux 
ENTÃO 
INÍCIO 
ide 
ENQUANTO j < cont d E disciplinas[j].cod d = 
matriculas[i].cod d FAÇA 
INÍCIO 
Jejai 
FIM 
ESCREVA disciplinas[j].descr 
ESCREVA matriculas[i].faltas 
ESCREVA matriculas[i].nota 
perc — disciplinas[j].carga hor * 25 / 100 
SE matriculas[i].faltas > perc OU matriculas[i].nota < 7 
ENTÃO ESCREVA “Reprovado” 
SENÃO ESCREVA “Aprovado” 
FIM 


FIM 
ATÉ op = 7 
FIM ALGORITMO. 


PASCAL [RSioRioitoR 
cmm \EXERC\CAP10\PASCAL\EX11.PAS e \EXERC\CAP10\PASCAL\EX11.EXE 


C/c++ ENIO: 
GEE \EXERC\CAP10\C++\EX11.CPP e \EXERC\CAP10\C++\EX11.EXE 


RB WIA A SoLução: 
GEE \EXERC\CAP10\JAVA\EX11.java e VEXERCACAP10NJAVANEX11.class 


EPA Faça um programa que receba a hora de início e de término de um jogo. Os valores deverão ser ex- 
pressos em quantidade de horas e de minutos; e também apenas em minutos e apenas em segundos. 


Considere que o tempo máximo de duração de um jogo é de 24 horas e que ele pode começar em um 
dia e terminar no outro. 


(AILIGIOJRILITIMO) SoLução: 


ALGORITMO 
DECLARE inicio, fim REGISTRO (hora, minuto NUMÉRICO) 
min, seg, hora total, min total NUMÉRICO 
REPITA 
LEIA inicio.hora 
ATÉ inicio.hora >= 0 E inicio.hora <= 23 
REPITA 
LEIA inicio.minuto 
ATÉ inicio.minuto >= 0 E inicio.minuto <= 59 
REPITA 
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LEIA fim.hora 
ATÉ fim.hora >= 0 E fim.hora <= 23 
REPITA 
LEIA fim.minuto 
ATÉ fim.minuto >= 0 E fim.minuto <= 59 
SE fim.minuto < inicio.minuto 
ENTÃO INÍCIO 
fim.minuto — fim.minuto + 60 
fim.hora — fim.hora — 1 
FIM 
SE fim.hora < inicio.hora 
ENTÃO INÍCIO 
fim.hora + fim.hora + 24 
FIM 
hora total + fim.hora — inicio.hora 
min total + fim.minuto — inicio.minuto 
ESCREVA hora total, min total 
min « hora total * 60 + min total 
ESCREVA min 
seg — min * 60 
ESCREVA seg 
FIM ALGORITMO. 


PASCAL [RSioRtoton 
GERE VEXERCACAP10NPASCALVEX12.PAS e NEXERCACAPIONPASCALNEX12.EXE 


C/C++ Sorução: 
\EXERC\CAP10\C++\EX12.CPP e VEXERCACAP10NC++NEX12.EXE 


[Dê 4] 
E-G- SoLução: 
cs \EXERC\CAP10\JAVA\EX12.java e \EXERC\CAP10\JAVA\EX12.class 


EEA Crie um programa que manipule uma lista contendo informações sobre dez pacientes (nome do pa- 
ciente, nome do médico, data de nascimento e sexo). Esse programa deverá implementar as seguintes 
rotinas: 


1. Cadastrar pacientes. 

2. Mostrar pacientes em ordem de cadastramento. 

3. Mostrar pacientes em ordem crescente (ordenar pelo nome). 
4. Mostrar pacientes em ordem decrescente (ordenar pelo nome). 
5. Excluir pacientes individualmente. 

6. Excluir pacientes por médico. 


Os elementos poderão ser inseridos sem qualquer ordenação (deve ser utilizado um vetor; não po- 
derão ser cadastrados mais de dez pacientes). 


Quando a lista for mostrada em ordem crescente ou decrescente, deve ser utilizada alguma maneira 
para não destruir a ordem original de cadastramento. 


Para realizar a exclusão de pacientes individualmente, deve ser informado o nome do paciente que 
se deseja remover. 


Para realizar a exclusão de pacientes por médico, deve ser informado o nome do médico cujos pa- 
cientes serão excluídos da lista. 
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(AILIGJOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE pacientes[10], pac cres[10], pac decres[10] REGISTRO (nome, nome med, data nasc, sexo 
© LITERAL) 
cont, cont p, i, j, op NUMÉRICO 
pac aux, med aux LITERAL 
cont p *< 1 
REPITA 
ESCREVA “1l-Cadastrar paciente” 
ESCREVA “2-Mostrar pacientes em ordem de cadastramento” 
ESCREVA “3-Mostrar pacientes em ordem crescente” 
ESCREVA “4-Mostrar pacientes em ordem decrescente” 
ESCREVA “5-Excluir pacientes individualmente” 
ESCREVA “6-Excluir pacientes por médico” 
ESCREVA “7-Finalizar” 
ESCREVA “Digite sua opção:” 
LEIA op 
SE op = 1 
ENTÃO 
INÍCIO 
SE cont p <= 10 
ENTÃO 
INÍCIO 
LEIA pac aux 
il 
ENQUANTO i < cont p E pacientes[i].nome * pac aux FAÇA 
INÍCIO 
i + i+ 1 
FIM 
SE i < cont_p 
ENTÃO ESCREVA “Paciente já cadastrado!” 
SENÃO 
INÍCIO 
pacientes[cont_p].nome < pac aux; 
LEIA pacientes[cont p].nome med 
LEIA pacientes[cont p].data nasc 
LEIA pacientes[cont p].sexo 
i — 1 
ENQUANTO i < cont p E pacientes[cont_p].nome > pac_cres[i].nome FAÇA 
INÍCIO 
i + i+ 1 
FIM 
SE i = cont p 
ENTÃO pac cres[cont p] «- pacientes[cont_p] 
SENÃO 
INÍCIO 
j *< cont p - 1 
ENQUANTO j >= i FAÇA 
INÍCIO 
pac cres[j+1] — pac cres[5] 
Ji en 
FIM 
pac cres[i] — pacientes[cont p] 
FIM 
il 
ENQUANTO i < cont p E pacientes[cont p].nome < pac decres[i].nome FAÇA 
INÍCIO 
i — i+ 1 
FIM 


SE i = cont p 
ENTÃO pac_decres[cont_p] — pacientes[cont_p] 
SENÃO INÍCIO 
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J + cont p - 1 
ENQUANTO j >= i FAÇA 
INÍCIO 
pac decres[jt+1] <« pac decres[5] 
Rss put 
FIM 
pac decres[i] — pacientes[cont p] 
FIM 
cont p <— cont p+ 1 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastrados 10 pacientes!” 
FIM 
SE op = 2 
ENTÃO INÍCIO 
PARA i — 1 ATÉ cont p - 1 FAÇA 
INÍCIO 
ESCREVA pacientes[i].nome 
ESCREVA pacientes[i].nome med 
ESCREVA pacientes[i].data nasc 
ESCREVA pacientes[i].sexo 
FIM 
FIM 
SE op = 3 
ENTÃO INÍCIO 
PARA i — 1 ATÉ cont p - 1 FAÇA 
INÍCIO 
ESCREVA pac cres[iJ].nome 
ESCREVA pac cres[i].nome med 
ESCREVA pac cres[i].data nasc 
ESCREVA pac cres[i].sexo 
FIM 
FIM 
SE op = 4 
ENTÃO INÍCIO 
PARA i < 1 ATÉ cont p - 1 FAÇA 
INÍCIO 
ESCREVA pac decres[i].nome 
ESCREVA pac decres[i].nome med 
ESCREVA pac decres[i].data nasc 
ESCREVA pac decres[i].sexo 
FIM 
FIM 
SE op = 5 
ENTÃO INÍCIO 
LEIA pac aux 
i — 1 
ENQUANTO i < cont p E pacientes[i].nome * pac aux FAÇA 
INÍCIO 
i | i+1 
FIM 
SE i = cont p 
ENTÃO ESCREVA “Paciente não cadastrado!” 
SENÃO INÍCIO 
ESCREVA “Paciente excluído com sucesso!” 
PARA j — i ATÉ cont p - 2 FAÇA 
INÍCIO 
pacientes[j] — pacientes[5+1] 
FIM 
i — 1 


ENQUANTO i < cont p E pac cres[i].nome * pac aux FAÇA 


Capítulo 10 Registro | 393 


INÍCIO 
i — i + dl 
FIM 
SE i = cont p 
ENTÃO ESCREVA “Paciente não cadastrado!” 
SENÃO INÍCIO 
PARA j — i ATÉ cont p - 2 FAÇA 


INÍCIO 
pac cres[j] = pac cres[j+1] 
FIM 
FIM 
i = dl 
ENQUANTO i < cont p E pac decres[i].nome * pac aux FAÇA 
INÍCIO 
i= i+1l 
FIM 


SE i = cont p 
ENTÃO ESCREVA “Paciente não cadastrado!” 
SENÃO INÍCIO 
PARA j — i ATÉ cont p - 2 FAÇA 


INÍCIO 
pac_decres[j] — pac_decres[j+1] 

FIM 

cont p + cont p - 1 

FIM 

FIM 
FIM 
SE op = 6 


ENTÃO INÍCIO 
LEIA med aux 
i — 1 
cont + cont_p 
ENQUANTO i < cont FAÇA 
INÍCIO 
SE pacientes[i].nome_med = med_aux 
ENTÃO INÍCIO 
PARA j — i ATÉ cont - 2 FAÇA 
INÍCIO 
pacientes[j] — pacientes[j+1] 
FIM 
cont < cont — 1 
FIM 
SENÃO i — i+1 
FIM 
SE i = cont p 
ENTÃO ESCREVA “Médico não cadastrado!” 
SENÃO INÍCIO 
ESCREVA “Pacientes excluídos com sucesso!” 
i — 1 
cont <— cont_p 
ENQUANTO i < cont FAÇA 
INÍCIO 
SE pac_cres[i].nome_med = med_aux 
ENTÃO INÍCIO 
PARA j — i ATÉ cont - 2 FAÇA 
INÍCIO 
pac_cres[j] — pac_cres[j+1] 
FIM 
cont + cont — 1 
FIM 
SENÃO i< i+1 
FIM 
i — 1 
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cont <— cont p 
ENQUANTO i < cont FAÇA 
INÍCIO 
SE pac decres[i].nome med = med aux 
ENTÃO INÍCIO 
PARA j — i ATÉ cont - 2 FAÇA 


INÍCIO 
pac decres[j] — pac decres[j+1] 

FIM 

cont + cont — 1 

FIM 

SENÃO i — i+1 
FIM 
cont p — cont 


FIM 


ATÉ op = 7 
FIM ALGORITMO. 


VSTO NH SOLUÇÃO: 
a \EXERC\CAP10\PASCAL\EX13.PAS e \EXERC\CAP10\PASCAL\EX13.EXE 


ylona SoLuçÃO: 
E \EXERC\CAP10\C++\EX13.CPP e \EXERC\CAP10\C++\EX13.EXE 


RNA SoLução: 
EE VEXERCACAP10NJAVANEX13. java e VEXERCACAP10NJAVANEX13.class 


ELJ Uma empresa patrocinadora de regatas deseja ter controle preciso sobre os participantes e os resul- 
tados, a fim de realizar adequadamente o pagamento dos prêmios. Dessa maneira, precisa cadastrar 
algumas informações, conforme apresentado a seguir: 


Regata (número da regata, data, hora de início, código do barco vencedor). 
Barco/Regata (número da regata, número do barco participante, hora de chegada). 
Barco (número do barco, nome do barco, ano de fabricação). 


Crie um programa que realize as seguintes rotinas: 


Cadastrar os barcos, não permitindo dois barcos com o mesmo número (deve ser definido espaço 
para seis barcos). 


Cadastrar as regatas, não permitindo duas regatas com o mesmo número (deve ser definido espaço 
para três regatas). 


Cadastrar os participantes (não permitindo cadastrar mais de uma vez um barco para a mesma re- 
gata, levando-se em consideração que em cada regata podem participar no máximo quatro barcos). 


Mostrar uma relação das regatas realizadas, junto com o nome do barco vencedor. 


Mostrar uma relação de todos os barcos que participaram de determinada regata, indicando o 
tempo que levaram para chegar ao fim da regata (considere que todas as regatas duram no máximo 
24 horas). 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE barcos[6] REGISTRO (num b, ano f NUMÉRICO nome LITERAL) 
regatas[3] REGISTRO (num r, cod venc, hora i NUMÉRICO data LITERAL) 
barco reg[12] REGISTRO (num r, num b, hora c NUMÉRICO) 
i, Jy k, cont b, cont r, cont rb, cont, reg aux, bar aux, op NUMÉRICO 
cont b< 1 
CONE so «= dl 
Contra 
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REPITA 
ESCREVA “1-Cadastrar barco” 
ESCREVA “2-Cadastrar regata” 
ESCREVA “3-Cadastrar participantes” 
ESCREVA “4-Cadastrar barco vencedor” 
ESCREVA “5-Mostrar regatas com seus vencedores” 
ESCREVA “6-Mostrar participantes de uma regata” 
ESCREVA “7-Finalizar” 
ESCREVA “Digite sua opção: “ 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
SE cont b <= 6 
ENTÃO INÍCIO 
LEIA bar aux 
i — 1 
ENQUANTO i < cont b E barcos[i].num b * bar aux FAÇA 
INÍCIO 
i — i+ 1 
FIM 
SE i < cont_b 
ENTÃO ESCREVA “Barco já cadastrado!” 
SENÃO INÍCIO 
barcos[cont b].num b + bar aux 
LEIA barcos[cont b].nome 
LEIA barcos[cont b].ano f 
cont b < cont b+ 1 
ESCREVA “Barco cadastrado com sucesso!” 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastrados 6 barcos!” 
FIM 
SE op = 2 
ENTÃO INÍCIO 
SE cont r <= 3 
ENTÃO INÍCIO 
LEIA reg aux 
i 1 
ENQUANTO i < cont r E regatas[i].num r = reg aux FAÇA 
INÍCIO 
i — i+1 
FIM 
SE i < cont_r 
ENTÃO ESCREVA “Regata já cadastrada!” 
SENÃO INÍCIO 
regatas[cont r].num r — reg aux 
LEIA regatas[cont r].data 
LEIA regatas[cont r].hora i 
regatas[cont r].cod venc + 0 
Contini conta 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastradas 3 regatas!” 
FIM 
SE op = 3 
ENTÃO INÍCIO 
LEIA reg aux 
il 
ENQUANTO i < contr E regatas[i].num r = reg aux FAÇA 
INÍCIO 
ici+l 
FIM 
SE i = cont r 
ENTÃO ESCREVA “Regata não cadastrada!” 
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SENÃO INÍCIO 
cont + 0 
PARA i — 1 ATÉ cont rb - 1 FAÇA 


INÍCIO 
SE barco_reg[i].num r = reg_aux 
ENTÃO cont — cont + 1 
FIM 


SE cont = 4 


FIM 
FIM 
SE op = 4 
ENTÃO INÍCIO 


ENTÃO ESCREVA “Já foram cadastrados 4 participantes nesta regata!” 
SENÃO INÍCIO 
LEIA bar aux 
1 = dl 
ENQUANTO i < cont b E barcos[i].num b = bar aux FAÇA 
INÍCIO 
i — i+1 
FIM 
SE i = cont_b 
ENTÃO ESCREVA “Barco não cadastrado!” 
SENÃO INÍCIO 
a s= dl 
ENQUANTO i < cont rb FAÇA 
INÍCIO 
SE bar aux = barco reg[i].num b E 
barco reg[i].num r = reg aux 
ENTÃO i — cont rb + 1 
SENÃO i < i+1 
FIM 
SE i > cont rb 


ENTÃO ESCREVA “Este barco já está participando desta 


= regata!” 

SENÃO INÍCIO 
barco reg[cont rb].num r + reg aux 
barco reg[cont rb].num b + bar aux 
LEIA barco reg[cont rb].hora c 
cont rb « cont rb + 1 

FIM 
FIM 
FIM 


LEIA reg aux 


i—o 
ENQUANTO 
INÍCIO 


i < cont r E regatas[i].num r + reg aux FAÇA 


i — i+ 1 


FIM 


SE i = cont _ r 
ENTÃO ESCREVA “Regata não cadastrada!” 
SENÃO INÍCIO 


LEIA bar_aux 

ala 

ENQUANTO j < cont_b E barco reg[j].num b + bar aux FAÇA 
INÍCIO 

Ies RA 

FIM 

SE j = cont_b 
ENTÃO ESCREVA “Este barco não participou desta regata!" 
SENÃO regatas[i].cod_venc + bar aux 


FIM 


FIM 
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SE op = 5 
ENTÃO INÍCIO 
PARA i — 1 ATÉ cont r - 1 FAÇA 
INÍCIO 
ESCREVA regatas[i].num r, regatas[i].data 
SE regatas[i].cod venc = 0 
ENTÃO ESCREVA “Ainda não foi cadastrado o barco vencedor!” 
SENÃO INÍCIO 
j-al 
ENQUANTO j < cont b E regatas[i].cod venc + barcos[j]. num b FAÇA 
INÍCIO 
ISA jd 
FIM 
SE j = cont b 
ENTÃO ESCREVA “Barco vencedor não cadastrado!” 
SENÃO ESCREVA barcos[j].nome 
FIM 
FIM 
FIM 
SE op = 6 
ENTÃO INÍCIO 
LEIA reg aux 
i — 1 
ENQUANTO i < cont r E regatas[i].num r + reg aux FAÇA 
INÍCIO 
i + i+ 1 
FIM 
SE i = cont r 
ENTÃO ESCREVA “Regata não cadastrada!" 
SENÃO INÍCIO 
ESCREVA regatas[i].num r, regatas[i].data 
PARA j — 1 ATÉ cont_rb - 1 FAÇA 
INÍCIO 
SE barco reg[j].num r = reg aux 
ENTÃO INÍCIO 
ke 1 
ENQUANTO k < cont b E 
barcos[k].num b + barco reg[j]. num b FAÇA 
INÍCIO 
le = Je sp dl 
FIM 
SE k < cont b 
ENTÃO ESCREVA barcos[k].num b, barcos[k].ano f 
FIM 
FIM 
FIM 
FIM 
ATÉ op = 7 
FIM ALGORITMO. 


PASCAI, SoLUÇÃO: 

a! VEXERCACAP10NPASCALNEX14.PAS e NEXERCACAPIONPASCALNEX14.EXE 
eyot Za SoLução: 

D \EXERC\CAP10\C++\EX14.CPP e \EXERC\CAP10\C++\EX14.EXE 


MS-GS- SoLução: 
D \EXERC\CAP10\JAVA\EX14.java e \EXERC\CAP10\JAVA\EX14.class 
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HA Uma pizzaria será informatizada e surgiu a necessidade de um controle eficaz do sistema de entrega em 
domicílio. Dessa maneira, serão utilizadas as informações a seguir: 
Clientes (número do telefone, nome do cliente, endereço, complemento, CEP). 
Pizzas (código da pizza, nome da pizza, valor). 
Pedido (número do pedido, número do telefone, código da pizza, código do motoqueiro, situação). 
Para simplificar, será considerado que: 
Existem cinco clientes cadastrados. 
Existem três pizzas cadastradas. 
Podem existir seis pedidos. 
O cliente é identificado pelo número de telefone. 
O campo ‘situação do pedido” refere-se às fases pelas quais o pedido passa até chegar à residência 
do cliente (1 — em preparo; 2 — a caminho; 3 — entregue). 


Saga Dor 


Faça um programa para realizar as seguintes tarefas: 


Criar uma rotina para o cadastramento das pizzas. Não pode haver mais que uma pizza com o 
mesmo código. 


Criar uma rotina para o cadastramento dos clientes. Não pode haver mais que um cliente com o 
mesmo número de telefone. 


Criar uma rotina para o cadastramento dos pedidos, supondo-se que o cliente e a pizza envolvidos 
já tenham sido cadastrados. Quando o pedido é cadastrado, o campo “situação” recebe o valor 1 e 
o campo “código do motoqueiro” recebe o valor zero. 


Criar uma rotina que faça o despacho da pizza, definindo o campo ‘situação’ para 2 e atribuindo o 
código do motoqueiro (que pode ser qualquer valor entre 1 e 5, inclusive). 


Criar uma rotina que faça o recebimento da pizza, alterando o campo ‘situação’ para 3. 
Mostrar o total gasto com pizzas por cliente. 

Mostrar todas as pizzas com determinada situação. 

Mostrar o código do motoqueiro que mais fez entregas. 


(ALLISIOJRNITIMO) Solução: 


ALGORITMO 
DECLARE clientes[5] REGISTRO (fone, nome cli, endereco, comple, cep LITERAL) 
pizzas[3] REGISTRO (cod piz, valor NUMÉRICO nome piz LITERAL) 
pedidos[6] REGISTRO (num ped, cod piz, cod mot, situacao NUMÉRICO fone LITERAL) 
cont piz, cont ped, cont cli NUMÉRICO 
i, j, k, op, ped aux, piz aux, total mot[5], maior, sit aux NUMÉRICO 
total cli[5] NUMÉRICO 
fone aux LITERAL 
cont piz — 1 
cont ped + 1 
Gone Gili = 1 
REPITA 
ESCREVA “1l-Cadastro de cliente” 
ESCREVA “2-Cadastro de pizza” 
ESCREVA “3-Cadastro de pedido” 
ESCREVA “4-Despachar pizza” 
ESCREVA “5-Receber pizza” 
ESCREVA “6-Mostrar total gasto por cliente” 
ESCREVA “7-Mostrar todos os pedidos com determinada situação 
ESCREVA “8-Mostrar motoqueiro que fez mais entregas 
ESCREVA “9-Finalizar” 
ESCREVA “Digite sua opção: ” 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
SE cont cli <= 5 
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ENTÃO INÍCIO 
LEIA fone aux 
i — 1 
ENQUANTO i < cont cli E clientes[i].fone = fone aux FAÇA 
INÍCIO 
ici+i 
FIM 
SE i < cont cli 
ENTÃO ESCREVA “Cliente já cadastrado!” 
SENÃO INÍCIO 
clientes[cont cli].fone + fone aux 
LEIA clientes[cont cli].nome cli 
LEIA clientes[cont cli].endereco 
LEIA clientes[cont cli].comple 
LEIA clientes[cont cli].cep 
contei Conticiidtii 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastrados 5 clientes!” 
FIM 
SE op = 2 
ENTÃO INÍCIO 
SE cont piz <= 3 
ENTÃO INÍCIO 
LEIA piz aux 
i — 1 
ENQUANTO i < cont _ piz E pizzas[i].cod piz = piz aux FAÇA 
INÍCIO 
ee l 
FIM 
SE i < cont piz 
ENTÃO ESCREVA “Pizza já cadastrada!” 
SENÃO INÍCIO 
pizzas[cont_piz].cod_piz + piz_aux 
LEIA pizzas[cont_piz].nome_piz 
LEIA pizzas[cont_piz].valor 
cont piz « cont piz + 1 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastradas 3 pizzas!” 
FIM 
SE op = 3 
ENTÃO INÍCIO 
SE cont ped <= 6 
ENTÃO INÍCIO 
LEIA ped aux 
i + 1 
ENQUANTO i < cont ped E pedidos[i].num ped + ped aux FAÇA 
INÍCIO 
e e l 
FIM 
SE i < cont_ped 
ENTÃO ESCREVA “Pedido já cadastrado!” 
SENÃO INÍCIO 
LEIA pedidos[cont ped].fone 
i — 1 


ENQUANTO i < cont cli E clientes[i].fone = pedidos[cont_ped]. 


= fone FAÇA 
INÍCIO 
i — i + 1 
FIM 
SE i = cont cli 
ENTÃO ESCREVA “Cliente não cadastrado!” 
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SENÃO 
INÍCIO 
LEIA pedidos[cont ped].cod piz 
i <- 1 
ENQUANTO i < cont_piz E 
pizzas[i].cod_piz = pedidos[cont_ped].cod_piz FAÇA 
INÍCIO 
i—ci+l 
FIM 
SE i > cont piz 
ENTÃO ESCREVA “Pizza não cadastrada!” 
SENÃO 
INÍCIO 
pedidos [cont ped].num ped — ped aux 
pedidos[cont ped].cod mot + 0 
pedidos[cont ped].situacao + 1 
cont ped + cont ped + 1 
FIM 
FIM 
FIM 
FIM 
SENÃO ESCREVA “Já foram cadastrados 6 pedidos!” 
FIM 
SE op = 4 
ENTÃO INÍCIO 
LEIA ped aux 
i 1 
ENQUANTO i < cont ped E pedidos[i].num ped + ped aux FAÇA 
INÍCIO 
i — i+ 1 
FIM 
SE i = cont ped 
ENTÃO ESCREVA “Pedido não cadastrado!” 
SENÃO INÍCIO 
SE pedidos[i].situacao = 1 
ENTÃO ESCREVA “Pedido já foi despachado!” 
SENÃO INÍCIO 
REPITA 
LEIA pedidos[i].cod mot 
ATÉ pedidos[i].cod mot >= 1 E pedidos[i].cod mot <= 5 
pedidos[i].situacao — 2 


FIM 
FIM 
FIM 
SE op = 5 
ENTÃO INÍCIO 
LEIA ped aux 
ie 1 
ENQUANTO i < cont ped E pedidos[i].num ped = ped aux FAÇA 
INÍCIO 
i — i+ 1 
FIM 


SE i = cont_ped 
ENTÃO ESCREVA “Pedido não cadastrado!" 
SENÃO INÍCIO 
SE pedidos[i].situacao = 1 
ENTÃO ESCREVA “Pedido ainda não foi despachado!” 
SENÃO SE pedidos[i].situacao = 3 
ENTÃO ESCREVA “Pedido já foi entregue!" 
SENÃO pedidos[i].situacao — 3 
PIM 
FIM 
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SE op = 6 
ENTÃO INÍCIO 
PARA i — 1 ATÉ 5 FAÇA 


INÍCIO 
total cli[i] — 0 
FIM 
PARA i <— 1 ATÉ cont ped - 1 FAÇA 
INÍCIO 
aj = dl 
ENQUANTO j < cont cli E clientes[j].fone + pedidos[i].fone FAÇA 
INÍCIO 
SJ DE) ia 
FIM 
k — 1 
ENQUANTO k < cont piz E pizzas[k].cod piz = pedidos[i].cod piz FAÇA 
INÍCIO 
ke k+1 
FIM 
total cli[j] <— total cli[j] + pizzas[k].valor 
FIM 
PARA i <— 1 ATÉ cont cli - 1 FAÇA 
INÍCIO 


ESCREVA clientes[i].nome cli 
ESCREVA total cli[i] 
FIM 
FIM 
SE op = 7 
ENTÃO INÍCIO 
SE cont ped = 0 
ENTÃO ESCREVA “Nenhum pedido foi cadastrado!” 
SENÃO INÍCIO 
LEIA sit aux 
SE sit aux = 1 E sit aux 2 E 
ENTÃO ESCREVA “Situação inexistente!” 
SENÃO INÍCIO 
J= 0 
PARA i — 1 ATÉ cont ped - 1 FAÇA 
INÍCIO 
SE pedidos [i].situacao = sit aux 
ENTÃO INÍCIO 
ESCREVA pedidos[i].num ped 
jel 
ENQUANTO j < cont piz E 
pizzas[j].cod piz + pedidos[i].cod piz FAÇA 


sit aux = 3 


INÍCIO 
jo ge i 
FIM 
ESCREVA pizzas[j].nome piz 
FIM 
FIM 
SE j = 0 
ENTÃO ESCREVA “Nenhum pedido nesta situação” 
FIM 
FIM 
FIM 
SE op = 8 ENTÃO 
INÍCIO 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 


total mot[i] — 0 
FIM 
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PARA i — 1 ATÉ cont ped - 1 FAÇA 
INÍCIO 
total mot[pedidos[i].cod mot] += total mot[pedidos[i].cod mot] + 1 
FIM 
PARA i — 1 ATÉ 5 FAÇA 
INÍCIO 
SE i=1l 
ENTÃO INÍCIO 
maior <— total mot[i] 
jei 
FIM 
SENÃO INÍCIO 
SE total mot[i] > maior 
ENTÃO INÍCIO 
maior — total mot[i] 
je-i 
FIM 
FIM 
FIM 
SE maior = 0 
ENTÃO ESCREVA “Nenhuma entrega foi realizada” 
SENÃO INÍCIO 


ESCREVA “O motoqueiro “, j, “ fez mais entregas” 
ESCREVA “Total geral de entregas: “, maior 
FIM 


FIM ATÉ op = 9 
FIM ALGORITMO. 


TARSO NH SOLUÇÃO: 
ed VEXERCACAP10NPASCALNEX15.PAS e NEXERCICAPIONPASCALNEX15.EXE 


C/c++ ENNIO 
e! \EXERC\CAP10\C++\EX15.CPP e \EXERC\CAP10\C++\EX15.EXE 


NB WIA NA SoLução: 
Es VEXERCACAP10ONJAVANEX15. java e VEXERCACAP10NJAVANEX15.class 


HA Faça um programa que solucione o problema de preenchimento de vagas nos cursos de uma universi- 
dade. Cada aluno que prestou vestibular na universidade originou um registro com os seguintes cam- 
pos: número de inscrição, idade, pontuação alcançada (de O a 5.000) e código do curso pretendido. 

A universidade oferece seis cursos, com 40 vagas cada. O problema consiste em distribuir os candidatos 
entre os cursos, de acordo com a nota final e com a opção apresentada pelo candidato. Em caso de empate, 
será atendido primeiro o candidato com maior idade. 

Sabe-se que o final da leitura dos dados será determinado pelo campo de inscrição negativo. Durante a 
leitura, os dados deverão ser repassados aos vetores (um vetor para cada curso). 

Como existe limite de vagas e não há ordem na leitura, o programa deverá criar vetores ordenados de 
maneira decrescente pela pontuação. Assim, aqueles que não conseguiram as 40 melhores pontuações serão 
descartados. 

O programa deverá mostrar a lista de alunos que foram aprovados em cada curso. 


(AILIGIOJRILITIM]O) SoLução: 


ALGORITMO 

DECLARE cand[6,40] REGISTRO (num insc, idade, pontos, cod curso NUMÉRICO) 
cont[6], i, j, k, insc_aux, idade_aux NUMÉRICO 
pontos_aux, curso_aux NUMÉRICO 

PARA i <— 1 ATÉ 6 FAÇA 
INÍCIO 
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cont[i] <— 40 
FIM 
LEIA insc aux 
ENQUANTO insc aux > 0 FAÇA 
INÍCIO 
LEIA idade aux 
REPITA 
LEIA pontos aux 
ATÉ pontos aux >= 0 E pontos aux <= 5000 
REPITA 
LEIA curso aux 
ATÉ curso aux >= 1 E curso aux <= 6 
i «e curso aux 
SE cont[i] = 40 
ENTÃO INÍCIO 
cand[i,40].num insc + insc_ 
aux cand[i,40].idade + idade aux 
cand[i,40].pontos < pontos aux 
cand[i,40].cod curso + curso aux 


cont[i] — cont[i] - 1 

FIM 

SENÃO INÍCIO 

j — 40 

ENQUANTO cand[i,j].pontos < pontos aux E j > cont[i] FAÇA 
INÍCIO 

p= aj dl 

FIM 


SE cont[i] <= 0 
ENTÃO INÍCIO 
PARA k — 40 ATÉ j+1 PASSO -1 FAÇA 
INÍCIO 
cand[i,k] <— cand[i,k-1] 
FIM 
cand[i,5+1].num insc — insc aux 
cand[i,j+l].idade <— idade aux 
cand[i,j+l].pontos + pontos aux 
cand[i,j+1l].cod curso — curso aux 
cont[i] — cont[i] - 1 
FIM 
SENÃO SE j = cont[i] 
ENTÃO INÍCIO 
cand[i,)].num insc — insc aux 
cand[i,j].idade <— idade aux; 
cand[i,j].pontos + pontos aux 
cand[i,j].cod curso + curso aux 
cont[i] — cont[i] - 1 
FIM 
SENÃO INÍCIO 
ENQUANTO cand[i,j].pontos = pontos aux E cand[i,j].idade 
= < idade aux E j > cont[i] FAÇA 
INÍCIO 
3 = 03) Sl 
FIM 
SE j >= cont[i] 
ENTÃO INÍCIO 
PARA k — cont[i] ATÉ j-1 FAÇA 


404 | Fundamentos da programação de computadores 


INÍCIO 
cand[i,k] — cand[i,k+1] 
FIM 
cand[i,j].num insc + insc aux 
cand[i,j].idade — idade aux 
cand[i,j].pontos + pontos aux 
cand[i,j].cod curso + curso aux 
cont[i] — cont[i] - 1 
FIM 
SENÃO INÍCIO 
cand[i,j].num insc + insc aux 
cand[i,j].idade — idade aux 
cand[i,j].pontos + pontos aux 
cand[i,j].cod curso < curso aux 


cont[i] — cont[i] - 1 
FIM 
FIM 
FIM 
LEIA insc aux 
FIM 
PARA i — 1 ATÉ 6 FAÇA 
INÍCIO 


SE cont[i] = 40 
ENTÃO INÍCIO 
ESCREVA “Lista de aprovados no curso”,i 
SE cont[i] <= 0 
ENTAO INICIO 
PARA j — 1 ATÉ 40 FAÇA 
INÍCIO 
ESCREVA cand[i][j].num insc 
ESCREVA cand[il][j].idade 
ESCREVA cand[il][j].pontos 
FIM 
FIM 
SE cont[i] >0 
ENTAO INICIO 
PARA j < cont[iltl ATÉ 40 FAÇA 
INÍCIO 
ESCREVA cand[i][j].num insc 
ESCREVA cand[i][j].idade 
ESCREVA cand[il][j].pontos 
FIM 
FIM 
FIM 
FIM 
FIM ALGORITMO. 


PASCAL SOLUÇÃO: 
\EXERC\CAP10\PASCAL\EX16.PAS e NEXERCICAPIONPASCALNEX16.EXE 


GER 
C/C++ Sorução: 
D \EXERC\CAP10\C++\EX16.CPP e \EXERC\CAP10\C++\EX16.EXE 


E-Go- SoLução: 
D \EXERC\CAP10\JAVA\EX16.java e \EXERC\CAP10\JAVA\EX16.class 


EFA Faça um programa que gerencie uma locadora de DVDs. Como se trata de uma locadora nova, ela não 
deve ter mais que dez clientes. Os dados sobre cada cliente são: código, nome, sexo, data de nascimen- 
to, RG, CPF, endereço, cidade, estado, número total de locações já feitas e número dos DVDs que estão 
locados atualmente. O código do cliente é o seu número no registro na locadora. O programa deverá: 
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a) Criar uma rotina que inclua um novo cliente. O número total de DVDs já locados e os locados atualmente 
deve ser zero. 

b) Criar uma rotina que mostre os clientes cadastrados. 

c) Criar uma rotina que remova um cliente, desde que ele não esteja com DVDs locados no momento. 

d) Criar uma rotina que faça a locação de novos DVDs a um cliente, desde que ele não tenha nenhum em seu 
poder. Deve-se entrar com o código do cliente e solicitar o número do DVD que deseja locar (nesse momento, 
o campo ‘DVDs locados atualmente” deve ser atualizado). 

e) Criar uma rotina para devolução de DVDs. Deve-se solicitar o código do cliente e, se for encontrado, pergun- 
tar quantos DVDs estão sendo devolvidos (o cliente não pode devolver mais DVDs do que o valor do campo 
‘número de DVDs locados atualmente”). Quando efetivar a devolução, os campos ‘DVDs locados atualmente” 
e “total de DVDs já locados” devem ser atualizados. 


f) Mostrar os clientes que estão com DVDs locados. 


(AJLIGIOJRILITIM]O) SoLução: 


ALGORITMO 
DECLARE clientes[10] REGISTRO (cod, dvd loc, tot dvd loc NUMÉRICO 
nome, sexo, data nas, RG, CPF, endereco, cidade, estado LITERAL) 
cont c, i, j, cod aux, qtd, op NUMÉRICO 

(fome, (e) «= dl 
REPITA 

ESCREVA “l-Cadastrar cliente” 

ESCREVA “2-Mostrar clientes” 

ESCREVA “3-Remover cliente” 

ESCREVA “4-Devolução de DVD” 

ESCREVA “5-Efetuar locação” 

ESCREVA “6-Mostrar clientes com DVDs locados” 

ESCREVA “7-Finalizar” 

ESCREVA “Digite sua opção:” 

LEIA op 

SE op = 1 

ENTÃO INÍCIO 
SE cont c <= 10 
ENTÃO INÍCIO 
LEIA cod aux 


i — 1 
ENQUANTO i < cont c E clientes[i].cod = cod aux FAÇA 
INÍCIO 
i i+1 
FIM 


SE i < cont c 
ENTÃO ESCREVA “Cliente já cadastrado!" 
SENÃO INÍCIO 
clientes[cont_c].cod < cod aux 
LEIA clientes[cont c].nome 
LEIA clientes[cont c].sexo 
LEIA clientes[cont c].data nas 
LEIA clientes[cont c].RG 
LEIA clientes[cont c].CPF 
LEIA clientes[cont c].endereco 
LEIA clientes[cont c].cidade 
LEIA clientes[cont c].estado 
clientes[cont c].dvd loc + 0 
clientes[cont c].tot dvd loc + 0 


(fome (8 = (elehe (O sr dl 
ESCREVA “Cliente cadastrado com sucesso!” 
FIM 
FIM 
SENÃO ESCREVA “10 clientes já foram cadastrados!” 
FIM 
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SE op = 2 
ENTÃO INÍCIO 
PARA i < 1 ATÉ cont c - 1 FAÇA 


INÍCIO 
ESCREVA clientes[i].cod 
ESCREVA clientes[i].nome 
ESCREVA clientes[i].sexo 
ESCREVA clientes[i].data nas 
ESCREVA clientes[i].RG 
ESCREVA clientes[iJ].CPF 
ESCREVA clientes[i].endereco 
ESCREVA clientes[i].cidade 
ESCREVA clientes[i].estado 
ESCREVA clientes[i].dvd loc 
ESCREVA clientes[i].tot dvd loc 

FIM 

FIM 


SE op = 3 
ENTÃO INÍCIO 
LEIA cod aux 


at = dl 
ENQUANTO i < cont c E clientes[i].cod = cod aux FAÇA 
INÍCIO 
i i+1 
FIM 


SE i < cont c 
ENTÃO INÍCIO 
SE clientes[i].dvd_loc > 0 
ENTÃO ESCREVA “Cliente não pode ser excluído, possui DVDs locados!” 
SENÃO INÍCIO 
PARA j — i+1 ATÉ cont c - 1 FAÇA 


INÍCIO 
clientes[j-1] — clientes[j] 

FIM 

cont c + cont c — 1 

ESCREVA “Cliente removido com sucesso!” 

FIM 
FIM 
SENÃO ESCREVA “Cliente não cadastrado!” 
FIM 
SE op = 4 


ENTÃO INÍCIO 

LEIA cod aux 

i — 1 

ENQUANTO i < cont c E clientes[i].cod = cod aux FAÇA 

INÍCIO 

a e ai aa Al 
FIM 
SE i < cont c 
ENTÃO INÍCIO 
SE clientes[i].dvd loc = 0 
ENTÃO ESCREVA “Este cliente não possui DVDs locados” 
SENÃO INÍCIO 
REPITA 
LEIA qtd 
SE qtd > clientes[i].dvd loc 
ENTÃO INÍCIO 
ESCREVA “Cliente possui apenas”, clientes[i].dvd . 
= loc, “locados"” 
ESCREVA “Digite a quantidade correta” 
LEIA qtd 
FIM 


Capítulo 10 Registro | 407 


ATÉ qtd <= clientes[i].dvd loc 


clientes[i].dvd loc — clientes[i].fitas dvd — qtd 


ESCREVA “Devolução efetuada com sucesso” 


FIM 
FIM 


SENÃO ESCREVA “Cliente não cadastrado!” 


FIM 


SE op = 5 


ENTÃO INÍCIO 


SE op = 6 


LEIA cod aux 
a = dl 


ENQUANTO i < cont c E clientes[i].cod = cod aux FAÇA 


INÍCIO 
i — i + 1 
FIM 
SE i < cont c 
ENTÃO INÍCIO 


SE clientes[i].dvd_loc > 0 


ENTÃO INÍCIO 


ESCREVA “Este cliente não pode fazer novas locações, pois possui 
= DVDs em seu poder” 


FIM 
SENÃO INÍCIO 


LEIA qtd 
clientes[i].dvd loc — qtd 
clientes[i].tot dvd loc + clientes[i].tot dvd loc + qtd 


ESCREVA “Locação efetuada com sucesso!” 


FIM 
FIM 


SENÃO ESCREVA “Cliente não cadastrado!” 


FIM 


ENTÃO INÍCIO 
PARA i < 1 ATÉ cont c - 1 FAÇA 


ATÉ op = 


INÍCIO 


SE clientes[i].dvd loc > 0 


ENTÃO INÍCIO 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 
ESCREVA 

FIM 


FIM 


7 


FIM_ALGORITMO. 


PASCAL 
E 


C/C++ 
ae] 


JAVA 
eee 


SOLUÇÃO: 


VEXERCACAP1ONPASCALNEX17.PAS e NEXERCACAP10NPASCALNEX17.EXE 


SOLUÇÃO: 


VEXERCACAP10NC++NEX17.CPP e NEXERCACAPIONC+HNEX17.EXE 


SOLUÇÃO: 


\EXERC\CAP10\JAVA\EX17.java e VEXERCACAPIONJAVANEX17.class 


C 
c 
C 
c 
c 
c 
c 
c 
c 
c 
C 


lientes[i] 
lientes[i] 


lientes[i] 
lientes[i] 
lientes[i] 


lientes[i] 
lientes[i] 
lientes[i] 
lientes[i] 


«cod 
-nome 
lientes[il. 
«data nas 
«RG 

-CPE 
lientes[i]. 
«Cidade 
«estado 

«dvd loc 
«tot dvd loc 


sexo 


endereco 
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EEJ Considere que um médico armazena algumas informações sobre seus 20 pacientes (nome, idade, sexo, 
altura e peso). Crie um programa que leia essas informações e determine: 


o nome da pessoa mais pesada; 
o nome e a idade das pessoas que estejam acima de seu peso ideal; 


os nomes das pessoas que estejam abaixo de seu peso ideal, mostrando ainda o peso que essas pes- 
soas deverão alcançar para atingir esse peso ideal. 

Utilize esses cálculos para determinar o peso ideal: 

Homens: (72,7 * altura) — 58 

Mulheres: (62,1 * altura) — 44,7 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE pac[20] REGISTRO (nome, sexo LITERAL idade, altura, peso NUMÉRICO) 
op, i, j, cont p, maior peso, peso ideal, dif NUMÉRICO 
nome aux[30] LITERAL cont p — 1 
REPITA 
ESCREVA “1- Cadastrar paciente” 
ESCREVA “2- Determinar paciente mais pesado” 
ESCREVA “3- Mostrar pacientes acima do peso ideal” 
ESCREVA “4- Mostrar pacientes abaixo do peso ideal” 
ESCREVA “5- Finalizar” 
ESCREVA “Digite sua opção: “ 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
SE cont p <= 20 
ENTÃO INÍCIO 
ESCREVA “Digite o nome do paciente: “ 
LEIA pac[cont p].nome 
REPITA 
ESCREVA “Digite o sexo do paciente (M ou F): ” 
LEIA pac[cont p].sexo 
ATÉ páac[cont p].sexo = “F” OU pac[cont_p].sexo = “M” 
ESCREVA “Digite a idade do paciente: “” 
LEIA pac[cont p].idade 
ESCREVA “Digite a altura do paciente (em metros): “” 
LEIA pac[cont p].altura 
ESCREVA “Digite o peso do paciente (em Kg): “ 
LEIA pac[cont p].peso 
concipi FCoOnNCIpRERI 
ESCREVA “Paciente cadastrado com sucesso!” 
FIM 
SENÃO ESCREVA “Já foram cadastrados 20 pacientes!" 
FIM 
SE op = 2 
ENTÃO INÍCIO 
SE cont p = 1 
ENTÃO ESCREVA “Nenhum paciente foi cadastrado” 
SENÃO INÍCIO 
PARA i < 1 ATÉ cont p - 1 FAÇA 
INÍCIO 
SE i= 1 
ENTÃO INÍCIO 
maior peso + pac[i].peso 
nome aux + pac[i].nome 
FIM 
SENÃO INÍCIO 
SE pac[i].peso > maior_peso 


Capítulo 10 Registro | 409 


ENTÃO INÍCIO 
maior peso — pac[i].peso 
nome aux + pac[i].nome 
FIM 
FIM 
FIM 
ESCREVA “Nome do paciente mais pesado: “, nome aux 
ESCREVA “Peso: ”, maior peso 
FIM 
FIM 
SE op = 3 
ENTÃO INÍCIO 
SE cont p = 1 
ENTÃO ESCREVA “Nenhum paciente foi cadastrado” 
SENÃO INÍCIO 


J = 0 
PARA i + 1 ATÉ cont p — 1 FAÇA 
INÍCIO 
SE pac[i].sexo = “F” 
ENTÃO peso ideal — (62.1 * pac[i].altura) - 44.7 
SENÃO peso ideal — (72.7 * pac[i].altura) - 58 


SE pac[i].peso > peso ideal 
ENTÃO INÍCIO 

j 1 
dif — pac[i].peso — peso ideal 
ESCREVA “Nome do paciente: “, pac[i].nome 
ESCREVA “Sexo do paciente: “, pac[i].sexo 
ESCREVA “Idade do paciente: “, pac[i].idade 
ESCREVA “Altura do paciente (em metros): “, pac[i].altura 
ESCREVA “Peso do paciente (em Kg):”, pac[i].peso 
ESCREVA “Precisa emagrecer”, dif, “ Kg para atingir seu 
= peso ideal” 


FIM 
FIM 
SE j=0 
ENTÃO ESCREVA “Nenhuma pessoa está acima do peso ideal” 
FIM 
FIM 
SE op = 4 


ENTÃO INÍCIO 
SE cont p = 1 
ENTÃO ESCREVA “Nenhum paciente foi cadastrado” 
SENÃO INÍCIO 


J = dO 
PARA i < 1 ATÉ cont p — 1 FAÇA 
INÍCIO 
SE pac[i].sexo = “F” 
ENTÃO peso ideal — (62.1 * pac[i].altura) - 44.7 
SENÃO peso ideal — (72.7 * pac[i].altura) — 58 


SE pac[i].peso < peso ideal 
ENTÃO INÍCIO 
j <=- 1 
dif — peso ideal - pac[i].peso 
ESCREVA “Nome do paciente: “, pac[i].nome 
ESCREVA “Sexo do paciente: “, pac[i].sexo 
ESCREVA “Idade do paciente: “, pac[i].idade 


ESCREVA “Altura do paciente (em metros): “, pac[i]. 
= altura 
ESCREVA “Peso do paciente (em Kg): “, pac[i].peso 


ESCREVA “Precisa adquirir”, dif, “ Kg para atingir seu 
= peso ideal” 
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FIM 
FIM 
SE j) = 0 
ENTÃO ESCREVA “Nenhuma pessoa está abaixo do peso ideal” 
FIM 


FIM ATÉ op = 5 
FIM ALGORITMO. 


PASCAL [RSioRtoiton 
ERES, VEXERCACAP10NPASCALVEX18.PAS e NEXERCACAPIONPASCALNEX18.EXE 


C/C++ Sorução: 
GEES \EXERC\CAP10\C++\EX18.CPP e \EXERC\CAP10\C++\EX18.EXE 


E-G SoLução: 
D \EXERC\CAP10\JAVA\EX18.java e \EXERC\CAP10\JAVA\EX18.class 


ELJ Faça um programa que controle o estoque de uma loja de brinquedos. Atualmente, no estoque há 40 
itens, cada um contendo código, descrição, preço de compra, preço de venda, quantidade em estoque 
e estoque mínimo. O programa deverá: 


Criar uma rotina para cadastrar os produtos. 


Criar uma rotina para mostrar o valor do lucro obtido com a venda de determinado produto e o 
percentual que esse valor representa. 


Criar uma rotina que mostre os produtos com quantidade em estoque abaixo do estoque mínimo 
permitido. 


EELER INIMO) Solução: 


ALGORITMO 
DECLARE brinquedos[40] REGISTRO (cod, qtd_est, est min, p compra, p venda NÚMERICO 
descr LITERAL) 
i, cont b, op, cod aux, lucro, perc, achou NUMÉRICO 
cont b + 1 
REPITA 
ESCREVA “1-Cadastrar brinquedo” 
ESCREVA “2-Mostrar lucro” 
ESCREVA “3-Mostrar produtos com estoque abaixo do estoque mínimo” 
ESCREVA “4-Finalizar” 
ESCREVA “Digite sua opção “ 
LEIA op 
SE op = 1 
ENTÃO INÍCIO 
SE cont b > 40 
ENTÃO ESCREVA “Já foram cadastrados os 40 brinquedos!” 
SENÃO INÍCIO 
LEIA cod aux 
i — 1 
ENQUANTO i < cont b E brinquedos[i].cod = cod aux FAÇA 
INÍCIO 
i — i + 1 
FIM 
SE i < cont_b 
ENTÃO ESCREVA “Já existe brinquedo com este código!” 
SENÃO INÍCIO 
brinquedos[cont_b].cod — cod aux 
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LEIA brinquedos[cont b].descr 
LEIA brinquedos[cont b].gtd est 
LEIA brinquedos[cont b].est min 
LEIA brinquedos[cont b].p compra 
LEIA brinquedos[cont b].p venda 
cont b < cont b+ 1 
ESCREVA “Brinquedo cadastrado com sucesso” 
FIM 
FIM 
FIM 
SE op = 2 
ENTÃO INÍCIO 
LEIA cod aux 
i — 1 
ENQUANTO i < cont_b E brinquedos[i].cod = cod aux FAÇA 
INÍCIO 
i — i+ 1 
FIM 
SE i < cont_b 
ENTÃO INÍCIO 
lucro — brinquedos[i].p venda - brinquedos[i].p_compra 
perc — lucro / brinquedos[i].p compra * 100 
ESCREVA lucro, perc 
FIM 
SENÃO ESCREVA “Brinquedo não cadastrado!” 


SE op = 3 
ENTÃO INÍCIO 
achou + 0 
PARA i — 1 ATÉ cont b - 1 FAÇA 
INÍCIO 
SE brinquedos[i].gtd est < brinquedos[i].est min 
ENTÃO INÍCIO 

achou — 1 
ESCREVA brinquedos[i].cod 
ESCREVA  brinquedos[i].descr 
ESCREVA brinquedos[i].gtd est 
ESCREVA brinquedos[i].est min 


FIM 
FIM 
SE achou = 0 
ENTÃO ESCREVA “Nenhum brinquedo está com estoque abaixo do estoque mínimo” 
FIM 
ATÉ op = 4 


FIM ALGORITMO. 


PASCAL [RSioRtoitoR 
Es VEXERCACAP10NPASCALVEX19.PAS e \EXERC\CAP10\PASCAL\EX19.EXE 
C/C++ [ESET 


E \EXERC\CAP10\C++\EX19.CPP e NEXERCÍCAP10NC++NEX19.EXE 


BAIANO SOLUÇÃO: 
EE VEXERCACAPIONJAVANEX19.java e NEXERCACAPIONJAVANEX19.class 


PTH A prefeitura de uma cidade fez uma pesquisa entre seus habitantes, coletando dados sobre o salário, 
idade, sexo e número de filhos. 
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Crie um programa que leia os dados de um número indeterminado de pessoas e, ao final, mostre: 
a) a média de idade das mulheres com salário inferior a R$ 700,00; 

b) a média de salário da população; 
c) a média do número de filhos; 


a menor idade. 


) 
) 
d) o maior salário; 
e) 


A leitura terminará quando for digitada idade igual a zero. 


(ALLISIOJRN ITIMO) Solução: 


ALGORITMO 
DECLARE pessoa REGISTRO (idade, filhos, salario NUMÉRICO sexo LITERAL) 
media id, media sal, media sa2, media fi, maior sa NUMÉRICO 
soma sal, soma sa2, soma fi NUMÉRICO menor id, contl, cont2 NUMÉRICO 
soma sal < 0 
soma sa2 < 0 
soma fi — 0 
conti — 0 
cont2 — 0 
menor id — 0 
maior sa <— 0 
LEIA pessoa. idade 
ENQUANTO pessoa.idade > 0 FAÇA 
INÍCIO 
LEIA pessoa.salario 
LEIA pessoa.sexo 
LEIA pessoa.filhos 
soma sal — soma sal + pessoa.salario 
contl — contl + 1 
soma fi — soma fi + pessoa-.filhos 
SE pessoa.sexo = “F” E pessoa.salario < 700 
ENTÃO INÍCIO 
soma sa2 — soma sa2 + pessoa.salario 
cont2 + cont2 + 1 
FIM 
SE conti = 
ENTÃO maior sa — pessoa.salario 
SENÃO SE pessoa.salario > maior sa 
ENTÃO maior sa — pessoa.salario 
SE conti = 1 
ENTÃO menor id — pessoa. idade 
SENÃO SE pessoa.idade < menor id 
ENTÃO menor id — pessoa. idade 
LEIA pessoa. idade 
FIM 
SE cont2 > 0 
ENTÃO media sa2 + soma sa2 / cont2 
SENÃO media sa2 — 0 
ESCREVA media sa2 
SE contl > 0 
ENTÃO INÍCIO 
media sal + soma sal / contl 
media fi — soma fi / contl 
FIM 
SENÃO INÍCIO 
media sal + 0 
media fi — 0 
FIM 
ESCREVA media sal 
ESCREVA media fi 
ESCREVA maior sa 
ESCREVA menor id 
FIM ALGORITMO. 
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PASCAI, SoLUÇÃO: 
D \EXERC\CAP10\PASCAL\EX20.PAS e \EXERC\CAP10\PASCAL\EX20.EXE 


eyler aa SoLuçÃo: 
\EXERC\CAP10\C++\EX20.CPP e \EXERC\CAP10\C++\EX20.EXE 


E 
BAIA SoLução: 
Ei NEXERCACAPIONJAVANEX20. java e NEXERCACAPIONJAVANEX20.class 


EXERCÍCIOS PROPOSTOS 


EEB Uma empresa deseja controlar as vendas realizadas por seus vendedores a cada mês, durante um ano inteiro. 
Sabe-se que nessa empresa existem quatro vendedores. 
É importante que esse controle seja automatizado, porque muitas consultas devem ser respondidas 
imediatamente. O gerente necessita de um meio para cadastrar as vendas de todos os vendedores e, 
depois, precisa ver um menu contendo as seguintes opções: 


Cadastrar vendedor. 

Cadastrar venda. 

Consultar as vendas de um funcionário em determinado mês. 

Consultar o total das vendas de determinado vendedor. 

Mostrar o número do vendedor que mais vendeu em determinado mês. 

Mostrar o número do mês com mais vendas. 

Finalizar o programa. 

Na opção 1: devem ser cadastrados vendedores, e não pode haver dois vendedores com o mesmo có- 
digo. 
Na opção 2: devem ser cadastradas vendas, informado o código do vendedor e o mês das vendas, mas 
não podem existir duas vendas para o mesmo vendedor no mesmo mês. 

Na opção 3: deve ser informado o número do vendedor e o número do mês que se deseja consultar, 
para, então, descobrir e mostrar esse valor. 

Na opção 4: deve ser informado o número do vendedor desejado, calculado e mostrado o total de suas 
vendas. 
Na opção 5: deve ser informado o número do mês que se deseja pesquisar, para então descobrir e mos- 
trar o número do vendedor que mais vendeu nesse mês. 

Na opção 6: deve ser descoberto e mostrado o mês com maior venda. 

Na opção 7: o programa termina. 


IFA A prefeitura de uma cidade fez uma pesquisa entre seus habitantes, coletando dados sobre salário, 
idade e número de filhos. Faça um programa que leia esses dados de 20 pessoas, calcule e mostre: 


E ON Re o Da 


a média de salário da população; 

a média do número de filhos; 

o maior salário; 

o percentual de mulheres com salário superior a R$ 1.000,00. 


IEJ Foi realizada uma pesquisa sobre algumas características físicas de 50 habitantes de certa região. De cada 
habitante foram coletados os seguintes dados: sexo, altura, idade e cor dos olhos (A — azuis; V — verdes; ou 


C — castanhos). 
Faça um programa que leia esses dados, armazene-os em um registro do tipo vetor e determine: 


a média de idade das pessoas com olhos castanhos e altura superior a 1,60 m; 
a maior idade entre os habitantes; 


a quantidade de indivíduos do sexo feminino com idade entre 20 e 45 anos (inclusive) ou que te- 
nham olhos verdes e altura inferior a 1,70 m; 


o percentual de homens. 
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EA Foi realizada uma pesquisa entre 20 habitantes de uma cidade. De cada habitante foram coletados estes dados: 
idade, sexo, renda familiar e número de filhos. Faça um programa que leia esses dados, armazenando-os em 
um vetor, calcule e mostre a média de salário entre os habitantes, a menor e a maior idade do grupo e a quan- 
tidade de mulheres com mais de dois filhos e com renda familiar inferior a R$ 600,00. 


EA Faça um programa que leia o código, a descrição, o valor unitário e a quantidade em estoque dos 50 produtos 
comercializados por uma papelaria. Essas informações devem ser armazenadas em um registro do tipo vetor 
em ordem crescente de código. Depois da leitura, o programa deverá: 


realizar uma rotina que permita alterar a descrição, o valor unitário e a quantidade em estoque de 
determinado produto, que deverá ser localizado por meio da informação de seu código; 


realizar uma rotina que mostre todos os produtos cuja descrição comece com determinada letra 
(informada pelo usuário); 


mostrar todos os produtos com quantidade em estoque inferior a cinco unidades. 
WA Leia as informações a seguir: 


Cliente Conta bancária 
Número do cliente Número da conta 
Nome Número do cliente 
Telefone Saldo 


Endereço 


Crie um programa que faça o cadastramento de contas, verificando se o número do cliente titular da 
conta já foi previamente cadastrado. Se existir, deverá permitir a inclusão. Caso contrário, deverá mos- 
trar a mensagem Cliente não cadastrado e abrir uma tela que permita o cadastramento. O programa 
deverá mostrar, ao final, todas as contas cadastradas. 


IEA Considere que exista um registro com os seguintes atributos: codigo cliente e nome cliente e outro 
registro com os seguintes atributos: Nº conta, valor compra, codigo cliente. Faça um programa 
que: 

inclua clientes, não permitindo que dois clientes possuam o mesmo código; 
inclua contas, verificando se o código do cliente informado já está cadastrado. Caso não esteja, não 
deverá permitir a inclusão; 


remova determinado cliente. Antes de executar a remoção, deverá verificar se ele não está vinculado 
a alguma conta. Se possuir, deverá mostrar a mensagem Exclusão não permitida. Caso contrário, 
deverá proceder à exclusão. 


REA Foi feita uma estatística em 15 estados brasileiros para coletar dados sobre acidentes de trânsito. Em cada 
estado foram observados os seguintes aspectos: 


nome do estado; 
número de veículos que circularam nesse estado (em 2012); 
número de acidentes de trânsito (em 2012). 
Crie um programa que permita conhecer: 
o maior e o menor índice de acidentes de trânsito e o nome dos estados em que eles ocorreram; 
o percentual de veículos em cada estado; 
a média de acidentes em cada um dos estados. 
EA Um funcionário recebe um salário fixo mais 6% de comissão sobre suas vendas. Crie um algoritmo que leia 


o salário do funcionário, o valor total de suas vendas, calcule a comissão e o salário final. O programa deverá 
mostrar todos os valores calculados. 


HA Uma empresa armazena informações sobre as contas a receber de seus clientes. Cada uma dessas contas 
tem as seguintes informações: número do documento, código do cliente, data de vencimento, data de 
pagamento, valor da conta e juros. Faça um programa para cadastrar um documento. Se a data de paga- 
mento for maior que a de vencimento, o programa deverá calcular o campo “juros” da tabela documentos 
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(a cada dia de atraso, deve-se aplicar 0,02% de multa). O programa deverá ler informações sobre 15 
documentos e, depois, mostrar todos os documentos lidos e o total geral a receber (valor das contas + 
juros) e a média dos juros. 


EEE Faça um programa que utilize as informações a seguir: 


Médicos Pacientes Consultas 
Cod medico Cod pac Num. prontuario 
Nome Nome pac Data consulta 
Endereco Endereco Diagnostico 
Salario Idade Cod medico 


Cod paciente 


O programa deverá: 

a) criar uma rotina para realizar inclusões e alterações no cadastro de pacientes e de médicos; 

b) criar uma rotina para excluir um médico (lembre-se: se existir alguma consulta realizada por esse médico, ele 
não poderá ser excluído); 

c) criar uma rotina para mostrar todas as consultas realizadas em uma data qualquer escolhida pelo usuário 
(lembre-se de mostrar também o nome do médico e o nome do paciente envolvido na consulta). 


EFA Observe os registros a seguir: 


Cliente Recebimentos 
Cod dl Num doc 
Nome Valor doc 
Endereco Data emissao 
Fone Data vencimento 
Cod cli 


Faça um programa que: 
a) inclua recebimentos (o programa deve verificar se o cliente já se encontra cadastrado); 
b) altere o cadastro de clientes (o usuário deve informar o código do cliente que será alterado); 


c) mostre todos os recebimentos com data de vencimento dentro de um período qualquer. Não esqueça de mos- 
trar também o nome do cliente e o total de dias em atraso (quando não houver atraso, o programa deverá 
mostrar zero); 


d) considere que poderão ser cadastrados no máximo três recebimentos para cada cliente. 
EEA Considere as informações a seguir: 

Estilista (código do estilista, nome do estilista, salário). 
Roupa (código da roupa, descrição da roupa, código do estilista, código da estação, ano). 
Estação (código da estação, nome da estação). 

Sabe-se que nessa indústria de confecção existem três estilistas. Faça um programa que: 

a) crie uma rotina para cadastrá-los; 

b) crie uma rotina para cadastrar as estações climáticas (sabendo que são duas: primavera-verão e outono- 
-Inverno); 

c) crie uma rotina para cadastrar as roupas (lembre-se de que estilista e estação devem ter sido previamente ca- 
dastrados) — no máximo dez roupas por estação; 

d) crie um relatório que mostre todas as roupas de determinada estação (informando, inclusive, o nome do esti- 
lista que a desenhou). 


ELA Utilize as informações a seguir para criar um controle automatizado de uma clínica médica. Sabe-se que 
essa clínica deseja ter um controle semanal (de segunda a sexta-feira) das consultas realizadas. A cada 
dia, cada médico pode realizar, no máximo, duas consultas. Considere que serão cadastrados três médi- 
cos e cinco pacientes. 
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Paciente(cod pac, nome, endereço, fone) 
Médico(cod med, nome, fone, endereço) 
Consulta(num consulta, dia semana, hora, cod med, cod pac) 


O programa deverá criar rotinas para: 


D 


cadastrar os pacientes, não permitindo dois pacientes com o mesmo código; 


Q 


b) cadastrar os médicos, não permitindo dois médicos com o mesmo código; 
) cadastrar as consultas, obedecendo às especificações apresentadas; 


d 


e) mostrar um relatório contendo todas as consultas realizadas em um dia. 


pesquisar as consultas de determinado médico em certo dia da semana (segunda a sexta-feira); 


HA Um restaurante deseja criar um controle de qualidade sobre os pratos que oferece a seus clientes. Dessa 
maneira, quer cadastrar algumas informações sobre as receitas, os ingredientes e os cozinheiros. As in- 
formações necessárias são descritas a seguir: 


Receita(codigo da receita, nome da receita, total de calorias a cada 100g, codigo co- 
zinheiro) 

Ingredientes (codigo do ingrediente, descricao) 

Ingredientes/Receita(codigo do ingrediente, codigo da receita, 

quantidade, unidade de medida) 

Crie um programa que: 


cadastre os cozinheiros (existem apenas três nesse restaurante); 

cadastre os ingredientes (existem no máximo 15); 

cadastre as receitas (existem 20 receitas que utilizam no máximo três ingredientes cada); 
mostre todas as receitas de determinado cozinheiro; 

mostre todas as receitas cujo total de calorias esteja dentro de um intervalo especificado; 
mostre o total de receitas elaboradas por cada um dos cozinheiros. 


HA O acervo de uma biblioteca precisa ser informatizado. Para tanto, as principais informações das obras 
foram assim estruturadas: 


Obra (numero do tombo, numero do exemplar, data compra) 
Tombo (numero do tombo, nome da obra, nome do autor, nome da editora, codigo da area) 


Sabe-se que existem 20 tombos e, para cada um, há no máximo três exemplares. 
Defina vetores de registro para armazenar tais informações. 

Defina o menu de opções a seguir: 

Cadastrar tombos. 

Cadastrar obras. 

Mostrar obras por área. 

Mostrar obras por autor. 

Mostrar obras por editora. 

Encerrar o programa. 


ON GA a SO 


Existem três áreas: 1 — exatas; 2 — humanas e sociais; e 3 — biomédicas. 


EFA Um banco está informatizando seus controles de clientes e contas. Sobre cada cliente dispõe-se dos se- 
guintes dados: nome, idade, endereço, número de suas contas (15 no máximo) e CPF CNPJ. As contas 
válidas têm número diferente de zero. Cada conta possui um só cliente. As informações das contas são as 
seguintes: número da conta, cliente e saldo atual. (Se existem 12 clientes com quatro contas no máximo, 
então devem existir 48 contas.) 


Crie um programa que: 

a) cadastre os clientes e suas contas; 

) mostre todas as contas cadastradas; 

c) mostre todas as contas de determinado cliente (identificadas pelo código); 
) mostre o somatório das contas de determinado cliente; 
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e) mostre todas as contas com saldo negativo; 

f) mostre o ativo bancário (soma de todos os saldos). 

EEJ Uma loja de eletrodomésticos está fazendo uma promoção entre seus 15 mil clientes. Todos os clientes 
que gastarem mais de R$ 5.000,00 em compras passarão a ser considerados clientes VIP, tendo 15% de 
desconto em todas as suas compras posteriores. Esse valor é cumulativo, mas precisa atingir R$ 5.000,00 
dentro de seis meses a partir da primeira compra ou será zerado. Faça um programa que: 

a) cadastre os clientes dessa loja. Para cada cliente devem ser cadastrados: nome do cliente, CPF, RG, endereço, 
data da primeira compra, total gasto desde sua primeira compra e um campo que diz se o cliente é VIP ou 
não. O campo que guarda o total gasto pelo cliente deve sempre iniciar com zero, e o campo em que diz se o 
cliente é VIP deve começar como FALSO; 

b) atualize o total gasto por determinado cliente. Deve-se ler um RG e, caso este seja encontrado na lista de 
clientes, deve-se entrar com um novo valor que atualizará o campo total gasto por esse cliente. Depois de 
entrar com o novo total gasto, deve-se fazer um teste para verificar se o valor chegou a R$ 5.000,00. Em caso 
positivo, o cliente passará a ser VIP. Esse teste só será realizado caso o cliente ainda não seja VIP; 

c) teste se o total gasto de cada cliente não VIP deve ser zerado. Se o tempo entre a data da primeira compra de 
um cliente e a data atual exceder seis meses, o total gasto por esse cliente deverá ser zerado. Lembre-se de que 
isso só vale para clientes não VIP. 


ELJ Uma empresa de eletrodomésticos está realizando um sorteio de uma Ferrari F-50, do qual participarão 
todos os que comprarem pelo menos cinco produtos de uma só vez nas lojas autorizadas. Faça um pro- 
grama que: 

a) leia os dados de todos os clientes, como nome, data de nascimento, CPF, RG, cidade em que mora, endereço e 
quantidade de eletrodomésticos adquiridos pelo cliente. Deve-se incluir um campo para o número do registro, 
que vai de 1 até 9999; 

b) faça o sorteio entre os clientes participantes. Somente os clientes que compraram mais que cinco equipamentos 
deverão participar. Será sorteado um número, e o cliente que tiver o registro com esse número será o ganhador. 


EIH Faça um programa contendo os serviços que uma oficina mecânica pode realizar: ordem de serviço (nú- 
mero da OS, data, valor, serviço realizado, cliente). 
Leia as informações sobre várias ordens de serviço e determine, ao final, a média dos valores, o nome 
do cliente que realizou o serviço mais caro, junto com a descrição desse serviço e a data de sua realização. 


CAPÍTULO 


11.1 Definição de arquivos em algoritmo 


Estruturas de dados manipuladas fora do ambiente do programa são conhecidas como arquivos. Con- 
sidera-se como ambiente do programa a memória principal, onde nem sempre é possível ou conveniente 
manter certas estruturas de dados. 

Um arquivo, que é armazenado em um dispositivo de memória secundária, como discos, por exemplo, 
pode ser lido ou escrito por um programa e é formado por uma coleção de caracteres (arquivo de texto) ou 
bytes (arquivo binário). 

Um sistema de banco de dados é composto por um ou vários arquivos. Cada um desses arquivos possui 
programas de manutenção, que são: inclusão, exclusão lógica ou exclusão física, alteração, consulta geral, 
consulta específica e relatórios. 

Existem dois tipos de exclusão de registros: a exclusão física, em que, após a eliminação de um registro, 
os demais são deslocados, e a exclusão lógica, em que os registros possuem um campo adicional, identi- 
ficando se estão ativos ou inativos, isto é, se foram excluídos. Nos exemplos apresentados neste capítulo, 
convencionou-se que, se o registro possuir o campo ATIVO com valor zero, significa que foi excluído. 


11.2 Trabalhando com arquivos em PASCAL 


11.2.1 Declaração de arquivos 


O primeiro passo para trabalhar com arquivos em PASCAL é a criação de novos tipos de dados, 
utilizando-se o TYPE. 

À seguir, mostramos um novo tipo de dado chamado nome do registro, onde é definido um registro 
composto por vários campos, que informará a estrutura dos dados que serão arquivados. O segundo tipo 
de dado é chamado nome do arquivo, que permitirá o arquivamento permanente de variáveis do tipo 
nome do registro. 


TYPE nome do registro = RECORD 
nome do campol: tipo do dadol; 
nome do campo2: tipo do dado2; 
nome do campoN: tipo do dadoN; 
END; 

nome do arquivo = FILE OF nome do registro; 

VAR variavel do arquivo : nome do arquivo; 

variavel do registro : nome do registro; 
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Exemplo 1: 

No exemplo 1, temos a definição de dois novos tipos de dados (a numeração das linhas não faz parte 
do programa). O primeiro tipo, registro, define as características de um registro, ou seja, informa que ele 
será composto pelos campos nome, endereco e€ telefone. Isso pode ser observado da linha 1 à 5. O segun- 
do tipo, arquivo, servirá para definir variáveis capazes de referenciar arquivos que armazenam dados no 
formato registro, como mostra a linha 6. Nas linhas 7 e 8, são declaradas variáveis dos tipos definidos 
anteriormente, ou seja, as informações geradas pelo programa serão armazenadas em REG. Posteriormente, 
a variável REG será gravada no arquivo referenciado por AGENDA. 


1. TYPE registro = RECORD 

2. nome : string[30]; 

Bo endereco : string[20]; 
4. telefone : string[10]; 
5. END; 

6. arquivo = FILE OF registro; 

7. VAR AGENDA : arquivo; 

8. REG : registro; 

Exemplo 2: 


No exemplo 2, também temos a definição de dois novos tipos de dados (a numeração das linhas não faz 
parte do programa). O primeiro tipo, carro, define as características de um registro, ou seja, informa que ele 
será composto pelos campos placa, marca e ano. Isso pode ser observado da linha 1 à 5. O segundo tipo, 
frota, servirá para definir variáveis capazes de referenciar arquivos que armazenam dados no formato carro. 
Nas linhas 7 e 8, são declaradas variáveis dos tipos definidos anteriormente. Ou seja, as informações geradas 
pelo programa serão armazenadas em CARROS. Posteriormente, a variável CARROS será gravada no arquivo 
referenciado por DETRAN. 


1. TYPE carro = RECORD 

Ze placa : string[7]; 
Bo marca : string[20]; 
4. ano : integer; 

5. END; 

6. frota = FILE OF carro; 

7. VAR DETRAN : frota; 

8. CARROS : carro; 


11.2.2 Associando variáveis a arquivos 


O comando AssIGN é utilizado para associar nomes de arquivos físicos a variáveis de um programa. 
Dessa forma, é possível estabelecer uma ligação entre a execução de um programa na memória principal e 
os dados armazenados na memória secundária, por exemplo, o disco rígido. 

O comando AssIGN tem a sintaxe apresentada a seguir. 

ASSICN(nome da variavel do tipo arquivo , 'caminho do arquivo no disco: nome do ar- 
quivo no disco”) ; 

Exemplo 1: 


ASSIGN (AGENDA, 'AGENDA.DAT'); 


A variável AGENDA permitirá acesso ao arquivo AGENDA. DAT. Como não foi especificado um caminho, o 
arquivo AGENDA. DAT deverá estar gravado no mesmo local do arquivo que estiver sendo executado. 


Exemplo 2: 
ASSIGN (DETRAN, 'C: VEXEMPLOSNCARROS. DAT! ); 


A variável DETRAN permitirá acesso ao arquivo CARROS. DAT. O arquivo CARROS. DAT deverá estar arma- 
zenado no caminho C: VEXEMPLOS. 
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11.2.3 Criando um novo arquivo 


Na linguagem PASCAL, novos arquivos podem ser criados utilizando-se o comando REWRITE. Se esse 
comando for usado, fazendo referência a um arquivo já existente, todos os seus dados serão destruídos, 
pois o comando REWRITE posiciona seu ponteiro no primeiro registro, apagando todo o seu conteúdo. Se o 
arquivo referenciado não existir, o comando REWRITE forçará sua criação. 

À sintaxe correta para o comando REWRITE é apresentada a seguir. 


REWRITE (nome da variavel do tipo arquivo); 


Exemplo 1: 
REWRITE (AGENDA) ; 


No exemplo 1, foi criado o arquivo associado à variável AGENDA. Se ele já existir, seus dados foram 
destruídos. 


Exemplo 2: 
REWRITE (DETRAN) ; 


No exemplo 2, foi criado o arquivo associado à variável DETRAN. Se ele já existir, seus dados foram 
destruídos. 


11.2.4 Abrindo arquivos já existentes 


O comando RESET deverá ser utilizado toda vez que for necessário abrir arquivos. Deve-se posicionar 
o ponteiro no primeiro registro, sem destruir os dados já existentes no arquivo. A sintaxe desse comando é 
apresentada a seguir. 


RESET (nome da variavel do tipo arquivo); 


Exemplo 1: 

RESET (AGENDA) ; 
No exemplo 1, foi aberto o arquivo associado à variável AGENDA, sem destruir os dados já existentes. 
Exemplo 2: 

RESET (DETRAN); 


No exemplo 2, foi aberto o arquivo associado à variável DETRAN, sem destruir os dados já existentes. 


11.2.5 Fechando um arquivo 


O comando crost é utilizado para fechar arquivos abertos pelo comando REWRITE ou pelo comando RE- 
SET. É importante salientar que todas as atualizações feitas em um arquivo só serão efetivadas quando ele for 
fechado. Além disso, nenhuma mudança poderá ser feita em um arquivo fechado. Observe a sintaxe a seguir. 


CLOSE(nome da variavel do tipo arquivo); 
Exemplo 1: 

CLOSE (AGENDA) ; 
No exemplo 1, foi fechado o arquivo associado à variável AGENDA. 
Exemplo 2: 

CLOSE (DETRAN) ; 


No exemplo 2, foi fechado o arquivo associado à variável DETRAN. 


11.2.6 Lendo dados de um arquivo 


Para ler os dados contidos em um arquivo, deve-se executar uma leitura no disco. Em PASCAL, isso pode 
ser feito por meio do comando READ, que possui a sintaxe a seguir. 


READ (nome da variavel do tipo arquivo, nome da variavel do tipo registro); 
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Exemplo 1: 


READ (AGENDA, REG); 


No exemplo 1, os dados lidos no arquivo associado à variável AGENDA serão copiados para a variável de 
programa REG. À partir daí, o programa tratará a variável REG como um registro qualquer. 


Exemplo 2: 


READ (DETRAN, CARROS); 


No exemplo 2, os dados lidos no arquivo associado à variável DETRAN serão copiados para a variável de 
programa CARROS. À partir daí, o programa tratará a variável CARROS como um registro qualquer. 


11.2.7 Gravando dados em um arquivo 


A linguagem PASCAL permite a gravação de dados usando-se o comando WRITE, como mostra a sintaxe 
a seguir. 


WRITE (nome da variavel do tipo arquivo, nome da variavel do tipo registro); 
Exemplo 1: 
WRITE (AGENDA, REG); 


No exemplo 1, os dados contidos na variável de programa REG serão copiados para o arquivo associado 
à variável AGENDA. 
Exemplo 2: 


WRITE (DETRAN, CARROS); 


No exemplo 2, os dados contidos na variável de programa CARROS serão copiados para o arquivo as- 
sociado à variável DETRAN. 


11.2.8 Movimentando o ponteiro em um arquivo 


O comando sEEk é utilizado para posicionar o ponteiro no registro desejado. O primeiro registro do 
arquivo é sempre o de número zero. À sintaxe do comando SEEK é apresentada a seguir. 


SEEK (nome da variavel do tipo arquivo, numero do registro); 
Exemplo 1: 
SEEK (AGENDA, 2); 


No exemplo 1, o ponteiro do arquivo AGENDA está na segunda posição, ou seja, no início do terceiro 
registro gravado no arquivo. 


Exemplo 2: 


SEEK (DETRAN, 0); 


No exemplo 2, o ponteiro do arquivo DETRAN está na posição zero, ou seja, no início do primeiro re- 
gistro gravado no arquivo. 


11.2.9 Obtendo o número de registros de um arquivo 


O comando FILESIZE é utilizado para retornar o número de registros existentes em um arquivo. A 
sintaxe desse comando é mostrada a seguir. 


FILESIZE (nome da variavel do tipo arquivo); 
Exemplo 1: 
tamanho := FILESIZE (AGENDA); 


No exemplo 1, é retornada para a variável tamanho a quantidade de registros gravados no arquivo 
AGENDA. 
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Exemplo 2: 
tamanho := FILESIZE(DETRAN); 
No exemplo 2, é retornada para a variável tamanho a quantidade de registros gravados no arquivo 
DETRAN. 


11.210 Obtendo a posição do ponteiro em um arquivo 


O comando FILEPOS é utilizado para retornar o número do registro onde o ponteiro está localizado. A 
forma correta para utilizar esse comando é: 


posicao := FILEPOS(nome da variavel do tipo arquivo); 
Exemplo 1: 
posicao := FILEPOS (AGENDA); 


No exemplo 1, é retornado para a variável posicao o número do registro onde o ponteiro do arquivo 
AGENDA está posicionado. 
Exemplo 2: 


posicao := FILEPOS (DETRAN); 


No exemplo 2, é retornado para a variável posicao o número do registro onde o ponteiro do arquivo 
DETRAN está posicionado. 


11.21 Verificando o final do arquivo 


O comando nor For é utilizado para verificar se o ponteiro chegou ao final do arquivo. O retorno desse 
comando poderá ser verdadeiro, caso o final tenha sido encontrado, ou falso, se acontecer o contrário. A 
seguir é mostrada a sintaxe do comando NOT EOF. 


WHILE NOT EOF(nome da variavel do tipo arquivo) DO 
BEGIN 
comandos ; 
END; 


Exemplo 1: 


WHILE NOT EOF (DETRAN) DO 
BEGIN 

READ (DETRAN, REG); 

END; 


O exemplo 1 mostrou como percorrer todos os registros de um arquivo. Observe que, dentro da estrutura 
de repetição WHILE, foi colocado o comando READ. Isso quer dizer que, a cada leitura feita no arquivo DETRAN, 
o ponteiro movimenta-se para o registro seguinte. Dessa forma, enquanto forem obtidas informações no ar- 
quivo, a repetição continuará. Quando o ponteiro chegar ao final do arquivo DETRAN, O WHILE será finalizado. 


11.3 Trabalhando com arquivos em C/C++ 


11.3.1 Declaração de arquivos 


Um arquivo em C/C++ pode representar diversas coisas, como arquivos em disco, uma impressora, um 
teclado, ou qualquer dispositivo de entrada ou saída. Este capítulo considera apenas arquivos em disco. 
Entretanto, ressaltamos que, caso o leitor queira manipular outros dispositivos, a interface é a mesma. 

A linguagem C/C++ dá suporte à utilização de arquivos por meio da biblioteca stdio.h. Essa biblioteca 
fornece várias funções para manipulação de arquivos, define novos tipos de dados a serem usados especi- 
ficamente com arquivos, como o tipo FILE. Uma variável do tipo ponteiro para FILE é capaz de identificar 
um arquivo no disco, direcionando para ele todas as operações. Essas variáveis são declaradas como qual- 
quer outro tipo de ponteiro. Observe, a seguir, que podemos ver duas variáveis, arg e pont, que podem 
referenciar arquivos em disco. 


FILE *arq, *pont; 
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Na linguagem C/C++, os dados podem ser gravados em arquivos binários ou de texto. Arquivos de 
texto podem ser lidos diretamente por qualquer editor de texto. Arquivos binários devem ser lidos por pro- 
gramas especiais, que convertem a cadeia de bits em informações compreensíveis. 


11.3.2 Abrindo arquivos 


A função fopen() abre um arquivo, retornando o ponteiro associado a esse arquivo. À sintaxe correta 
para sua utilização é: 
FILE *p; 
p = fopen(nome do arquivo, modo de abertura); 


onde: 

p é uma variável que armazenará o endereço inicial de memória ocupado por um arquivo (se, por 
qualquer motivo, o arquivo não puder ser aberto, a variável p receberá o valor NULL); 

nome do arquivo representa o nome do arquivo que se deseja abrir, podendo conter, inclusive, o cami- 
nho (path) da pesquisa; 

modo de abertura representa como o arquivo será aberto. A tabela a seguir descreve todos os modos 
de abertura. 


r Abre um arquivo de texto onde poderão ser realizadas apenas leituras. 
w Cria um arquivo de texto onde poderão ser realizadas apenas operações de escrita. 
a Anexa novos dados a um arquivo de texto. 
rb Abre um arquivo binário onde poderão ser realizadas apenas leituras. 
wb Cria um arquivo binário onde poderão ser realizadas apenas operações de escrita. 
ab Anexa novos dados a um arquivo binário. 
r+ Abre um arquivo de texto onde poderão ser realizadas operações de leitura e de escrita. 
w+ Cria um arquivo de texto onde poderão ser realizadas operações de leitura e de escrita. 
a+ Anexa novos dados ou cria um arquivo de texto para operações de leitura e de escrita. 
rb+ Abre um arquivo binário onde poderão ser realizadas operações de leitura e de escrita. 
wb+ Cria um arquivo binário onde poderão ser realizadas operações de leitura e de escrita. 
ab+ Anexa novos dados a um arquivo binário para operações de leitura e de escrita. 

Exemplo 1: 

FILE *arg; 


arq = fopen(“arquivol.dat”,"w”); 


No exemplo 1, a função fopen() criou um arquivo chamado arquivol.dat, onde poderão ser realiza- 
das operações de escrita (gravação), pois foi utilizado o modo de abertura w. 
Quando a função fopen() é utilizada para abrir um arquivo no modo escrita (w e wb), duas situações 
podem ocorrer: 
se o arquivo não existir, ele será criado; 
se o arquivo já existir, ele será sobreposto por um novo arquivo vazio. 


Se a função fopen() for executada sem problemas, a variável arg receberá o endereço de memória ocu- 
pado pelo arquivo. Caso algum erro ocorra, a variável arg receberá o valor NULL. Sendo assim, é recomen- 
dável a realização de um teste para verificar se o arquivo foi aberto adequadamente. Observe o Exemplo 2. 


Exemplo 2: 


1. finclude <stdio.h> 

2. int main() 

So ETLER arq, 

4. arq = fopen(“arquivol.dat”,"r"); 

5. if (arq == NULL) 

6. { printf(“\nOcorreu um erro. O arquivo não foi aberto.” ); 
To 


; 
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8. else 

9. { /* As demais instruções do programa só poderão ser 
10. executadas se o arquivo foi aberto de forma correta. 
lilo */ 

12 


13. // continuação do programa 
14.return 0; 
15.) 


Na linha 4, a função fopen() foi utilizada para abrir um arquivo já existente somente no modo leitura 
(r). Se o arquivo for encontrado e aberto corretamente, a variável arg receberá o seu endereço, caso contrá- 
rio, a variável arg receberá NULL. 


900 Observações 


A função fopen() não é capaz de criar pastas, pode apenas criar arquivos quando o modo de 
abertura escolhido assim o permitir. Caso você não tenha certeza de que a pasta já existe no disco, 
poderá construí-la antes de tentar abrir o arquivo. Para isso, deverá fazer uso da função system(), 
pertencente à biblioteca stdlib.h. 

A função system() passa uma string como um comando para o processador. Com ela, é pos- 
sível a realização das mesmas operações em linha de comando de um sistema operacional, como 
criação de pastas (diretórios), listagem do conteúdo de uma pasta (diretório), renomear arquivo, 
copiar arquivo, dentre outras. 


Exemplo 1: 


#include <stdlib.h> 

int main() 

{ system(“md C:\\exemplo\\teste”); 
return 0; 


No exemplo 1 a função system() foi utilizada para criar o caminho C:\exemplo\teste. A string pas- 
sada como parâmetro utilizou o comando ma, padrão Windows (foi necessária a utilização de duplas barras 
invertidas para evitar que o compilador fizesse confusão com caracteres de controle, por exemplo, a marca 
de nova linha \n ou de tabulação \t). 


Exemplo 2: 


#include <stdlib.h> 

int main() 

{ system(“mkdir -p /home/usuario/exemplo/teste/"); 
return 0; 


No exemplo 2, a função system() foi utilizada para criar o caminho /home/usuario/exemplo/teste. 
À string passada como parâmetro utilizou o comando mkdir, padrão Unix. 


11.3.3 Fechando um arquivo 


A função fclose() fecha um arquivo. Quando ocorrer algum erro durante a execução da função, poderá 
haver perda de dados ou até mesmo perda do arquivo. O protótipo dessa função é: 


int fclose(FILE *arqg); 


onde arg é a referência para o arquivo (arg é o ponteiro obtido quando o arquivo foi aberto). 
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Quando a função fclose() é executada, gera como resultado um número inteiro. Se esse número for 
igual a zero, significa que o arquivo foi fechado corretamente. Caso contrário, houve erro na operação. 

O exemplo a seguir mostra a utilização da função fclose() (as linhas à esquerda não fazem parte do 
programa). 


1. finclude <stdio.h> 

2. int main() 

3. { FILE *p; 

4. int resposta; 

5. p = fopen(“arquivo.txt”, “w"); 

6. if (p == NULL) 

To printf(“ÍnErro na abertura”); 

8. else ( printf(“inSucesso na abertura”); 

Se resposta = fclose(p); 

10. if (resposta == 0) 

Tiz printf (“inSucesso no fechamento”); 
2% else printf(“inErro no fechamento”); 
137 } 

14. return 0; 

15.3} 


Na linha 5, a função fopen() abriu o arquivo arquivo. txt no modo escrita, associando seu endereço 
à variável p. Se o valor da variável p for diferente de NULL, o arquivo foi aberto corretamente e as operações 
de escrita poderão ser executadas. Na linha 9, a função fclose() usa o endereço guardado na variável p 
para fechar o arquivo arquivo .txt. Se o valor da variável resposta for igual a zero o arquivo foi fechado 
corretamente. 

Qualquer problema que ocorra com a execução de um programa poderá corromper, ou seja, danificar 
os arquivos que estiverem abertos. Assim, é aconselhável que sejam mantidos abertos o menor tempo pos- 
sível. 


11.3.4 Capturando erros durante o uso de arquivos 


A função ferror() detecta se ocorreu algum erro durante uma operação com arquivos. O protótipo 
dessa função é: 


int ferror(FILE *arqg); 


A função ferror ( )retorna um número inteiro e deve ser chamada logo depois da invocação de qualquer 
outra função de manipulação de arquivo. Se o valor retornado pela função ferror() for diferente de zero, 
significa que ocorreu um erro durante a última operação realizada com o arquivo; caso contrário não ocor- 
reu erro. 

Os exemplos apresentados nas próximas seções demonstrarão o emprego da função ferror(). 


11.3.5 Gravando caracteres em um arquivo 
A função fputc() escreve um caractere em um arquivo. Sua sintaxe correta é: 


fputc(char ch, FILE *arg); 


onde: 
ch é o caractere que será escrito no arquivo; 
arq é a referência para o arquivo onde o caractere será escrito. 


O exemplo a seguir ilustra a utilização da função fputc() (as linhas à esquerda não fazem parte do 
programa). 


1. finclude <stdio.h> 
2. int main() 

3. { FILE *p; 

4 char carac; 
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5 p = fopen(”“C:\\exemplo\\teste\\caract.dat”", “a"); 
6. if (p == NULL) 

7 printf(“\nErro na abertura”); 

8 


else 
So { printf(“AnDigite um caractere: “); 
10. scanf (“%c%*c", &carac); 
ris while (carac != '£f') 
12% { fputc(carac, p); 
Isto if (ferror(p)) 
14. printf (“inErro na gravação do caractere”); 
15. else printf(“inGravação realizada com sucesso”); 
16. printf(“AnDigite outro caractere: ”); 
17 scanf(“%c%*c”, &carac); 
18. } 
19. } 


20. fclose(p); 
21. return 0; 
22.) 


A linha 9 solicitou que fosse digitado um caractere qualquer. A linha 10 recebeu o caractere digitado, 
armazenando-o na variável carac. Da linha 11 à 18, existe uma estrutura de repetição que permitiu a digi- 
tação de inúmeros caracteres. A repetição terminou quando foi digitado o caractere £, fazendo referência à 
finalização. Cada vez que esse bloco de linhas foi executado, a função fputc(), na linha 12, gravou o carac- 
tere digitado no arquivo referenciado pela variável p. A linha 13 utilizou a função ferror() para verificar 
se a gravação ocorreu corretamente. Na linha 20, o arquivo foi fechado. 


11.3.6 Lendo caracteres de um arquivo 
A função fgetc() lê um caractere de um arquivo. Seu protótipo é: 
int fgetc(FILE *arg); 


onde: 

arq é a referência para o arquivo de onde o caractere será lido. 

Se a execução da função fgetc() for bem-sucedida, gerará como retorno o valor do caractere lido 
(esse valor poderá ser armazenado em uma variável int, já que é o valor ASCII, ou em uma variável char, 
exigindo a conversão do valor ASCII para o caractere correspondente). Caso ocorra algum erro na leitura, 
o valor devolvido será Eor. 

O exemplo a seguir demonstra o uso da função fgetc() (a numeração à esquerda das linhas não faz 
parte do programa). 


1. finclude <stdio.h> 

2. int main() 

3. { FILE *p; 

4. char carac; 

5. p = fopen(“caract.dat”, “r"); 
6. if (p == NULL) 

7 printf(“inErro na abertura”); 
8. else 

Do 

10. do { 

Milo carac = fgetc(p); 

12; if (ferror(p)) 

T7 printf(“\nErro na leitura do caractere”); 
14. else 


Do { if (!feof(p)) 
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16. { printf(“AnLeitura realizada com sucesso”); 
7 printf(“Caractere lido: %c” , carac); 

18. } 

19. , 

20. } while (!feof(p)); 

Dito 


22. fclose(p); 
23.return 0; 
24.) 


Dalinha 10â 20, existe uma estrutura de repetição do-while, que permitiu a leitura dos caracteres gravados 
no arquivo, acessado por meio da variável p. Na linha 11, a função fgetc() leu um caractere do arquivo refe- 
renciado, armazenando-o na variável carac. A linha 12 utilizou a função ferror() para verificar se a leitura 
se deu corretamente. A linha 15 utilizou a função feof () para verificar se após a leitura o fim do arquivo foi en- 
contrado. Isso foi importante para não mostrar o caractere indicativo de fim de arquivo. A repetição terminará 
quando for detectado o fim do arquivo. Isso é feito na linha 20, novamente utilizando-se a função feof () — 
a Seção 11.3.11 apresentará a função feof () em detalhe. Na linha 22, o arquivo foi fechado. 


11.3.7 Gravando uma cadeia de caracteres em um arquivo 
A função fputs() escreve uma cadeia de caracteres em um arquivo. O protótipo dessa função é: 


fputs(char *cadeia, FILE *arqg); 


onde: 

cadeia armazena a cadeia de caracteres que será escrita no arquivo. 

arg é a referência para o arquivo em que a cadeia de caracteres será escrita. 

O exemplo a seguir ilustra a utilização da função fputs () (a numeração à esquerda das linhas não faz 
parte do programa). 


1. finclude <stdio.h> 

2. int main() 

3. { FILE *p; 

4. char cadeia[30]; 

5. p = fopen(“C: lexemplolitestelicadeias.txt”, “a”); 
6. if (p == NULL) 

To printf (“AnErro na abertura”); 

8. else 

9. { printf(“AnDigite uma cadeia de caracteres: "); 
10. gets(cadeia); 

ibai while (stricmp(cadeia, “fim”) != 0) 

12. { fputs(cadeia, p); 

Sa if (ferror(p)) 

14. printf(“AnErro na gravação da cadeia”); 

15. else 

16. printf (“inGravação realizada com sucesso”); 
7a printf(“AnDigite outra cadeia: “); 

18. gets (cadeia); 

19. } 

20, É 


21. fclose(p); 
22. return 0; 
23.5 


A linha 9 solicitou que fosse digitada uma cadeia de caracteres qualquer. A linha 10 recebeu a cadeia 
digitada, armazenando-a na variável cadeia. Da linha 11 à 19, existe uma estrutura de repetição que permi- 
tiu que fossem digitadas inúmeras cadeias. A repetição terminou quando foi digitada a cadeia fim, fazendo 
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referência à finalização. Cada vez que esse bloco de linhas foi executado, a função fputs() gravou a cadeia 
de caracteres digitada no arquivo referenciado pela variável p. A linha 13 utilizou a função ferror() para 
verificar se a gravação ocorreu corretamente. Na linha 21, o arquivo foi fechado. 


11.3.8 Lendo cadeias de caracteres de um arquivo 


A função fgets () lê uma cadeia de caracteres armazenada em um arquivo. A cadeia será formada por todos 
os caracteres existentes, da posição atual do ponteiro do arquivo até uma marca de nova linha ou até que tam 
— 1 caracteres fossem lidos (tam é um dos parâmetros utilizados pela função). A sintaxe correta dessa função é: 


fgets(char *cadeia, int tam, FILE *arg); 


onde: 


cadeia armazena a cadeia de caracteres obtida do arquivo; 
tam indica que a quantidade máxima de caracteres lidos será tam - 1; 
arg é a referência para o arquivo. 


O exemplo a seguir ilustra a utilização da função fgets() (a numeração à esquerda das linhas não faz 
parte do programa). 


1. finclude <stdio.h> 

2. int main() 

3. { FILE *p; 

4. char cadeia[5]; 

5. p = fopen(“c:NlexemplolNtestelicadeias.txt”, “r"); 
6. if (p == NULL) 

Ts printf(“ÍnErro na abertura”); 

8. else 

9. 4 while (!feof(p)) 

10. { fgets(cadeia, 5, p); 

Ti. if (ferror(p)) 

d2 printf(“\nErro na leitura da cadeia”); 

3 else 

14. { printf(“AnLeitura realizada com sucesso”); 
15 printf(“Cadeia lida: %s” , cadeia); 

16. } 

17. `} 

18. 3 


19. getchar(); 
20. fclose(p); 
21. return 0; 


Da linha 9 à 17, uma estrutura de repetição permitiu que fossem lidas todas as cadeias de caracteres 
gravadas no arquivo. Na linha 10, a função fgets() leu uma cadeia de 5 - 1 caracteres contida no arqui- 
vo referenciado por p, armazenando-a na variável cadeia (cujo tamanho é 5, para ter na última posição a 
marca de fim de cadeia). 

A função fgets() fez a leitura até atingir 5 — 1 caracteres ou até encontrar uma marca de nova linha. 
A linha 11 utilizou a função ferror() para verificar se a leitura ocorreu corretamente. A repetição termi- 
nou quando foi detectado o fim do arquivo. Isso foi feito na linha 9, por meio da função feof(), que será 
apresentada em detalhes na Seção 11.3.11. Na linha 20, o arquivo foi fechado. 


11.3.9 Gravando qualquer tipo de dado em um arquivo 


Arquivos em C/C++ não podem ser associados a um tipo primitivo de dados ou a um registro (struct). 
Os arquivos simplesmente armazenam uma sequência de caracteres ou uma sequência de bytes. 
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Entretanto, em vários momentos, é mais útil e mais prático ler parte do conteúdo de um arquivo e gra- 
var diretamente em uma variável int ou float, ou, ainda, em uma variável struct. Também é importante 
conseguir pegar o conteúdo de variáveis desses tipos e gravá-lo diretamente em um arquivo. 

Quando isso for necessário, o programa deverá trabalhar com arquivos binários. Toda vez que uma opera- 
ção de leitura ou de escrita for realizada, deverá ser informado o número de bytes que serão lidos ou gravados. 
Para isso, a função sizeof() será utilizada intensamente, uma vez que por meio dela é possível descobrir quan- 
tos bytes uma variável (de qualquer tipo, incluindo struct) ocupa. 

A função fwrite() pode escrever qualquer tipo de dado, e não apenas caracteres ou cadeias de carac- 
teres. O protótipo dessa função é: 


int fwrite(void *mem, size_t gtd bytes, size_t cont, FILE *arg); 


onde: 


mem representa a variável que armazena o conteúdo a ser gravado no arquivo; 

gtd bytes representa o total em bytes que será escrito no arquivo; 

cont representa o número de blocos de tamanho gtd bytes que serão escritos no arquivo; 

arg é a referência para o arquivo onde as informações serão escritas. 

Quando a função fwrite() for bem-sucedida, gerará como retorno um valor igual ao número de 
gravações realizadas (igual ao parâmetro cont informado). Se ocorrer algum erro, o valor retornado será 
menor que cont. 

O exemplo a seguir ilustra a utilização da função fwrite() (a numeração à esquerda das linhas não 
faz parte do programa). 


1. finclude <stdio.h> 

2. int main() 

3. { struct cliente 

4. { int numero; 

Do char nome[20]; 

6. E 

7. FILE *cli; 

8. struct cliente c; 

9. cli = fopen(“c:lVexemplolitesteliclientes.dat”, “a+"); 
10. if (cli == NULL) 

110 printf(“inErro na abertura do arquivo”); 

12. else 

13. 4 printf(“AnDigite o número do cliente a ser incluído “); 
14. scanf(“3d$*c”, &c.numero) ; 

So printf(“Digite o nome do cliente a ser incluído “); 
16. gets(c.nome); 

I7: fwrite(&c, sizeof(struct cliente), 1, cli); 

18. if (ferror(cli)) 

19. printf(“Erro na gravação “); 

20. else printf (“Gravação realizada com sucesso “); 

2A fclose(cli); 

227 


23. getchar(); 
24. return 0; 
25.5) 


Nesse exemplo, foi descrito como fazer gravações de dados do tipo cliente, definido na struct da 
linha 3 à 6. Pode-se observar que, nessa struct, existem dois campos, numero e nome. Na linha 14, foi re- 
cebido um valor, armazenando-o em c.numero. Na linha 16, foi recebido outro valor, armazenando-o em 
c.nome. Dessa forma, a variável c ficou completamente preenchida. Na linha 17, a função fwrite() foi exe- 
cutada, ou seja, o conteúdo da variável c foi gravado no arquivo referenciado por cli. A linha 18 utilizou 
a função ferror() para verificar se a gravação ocorreu corretamente. Na linha 21, o arquivo foi fechado. 
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Os quatro parâmetros utilizados na função fwrite() significam: 

sc — dados que serão gravados no arquivo; 

sizeof(struct cliente) — tamanho do bloco de gravação, ou seja, tamanho em bytes ocupados por 
variáveis do tipo struct cliente; 

1 — quantidade de blocos do tamanho de sizeof (struct cliente) que serão gravados; 

cli — referência para o arquivo onde será feita a gravação. 


11.310 Lendo qualquer tipo de dados de um arquivo 


A função fread() pode ler qualquer tipo de dados e não apenas caracteres ou cadeias de caracteres. A 
sintaxe correta para sua utilização é: 


int fread(void *mem, size_t gtd bytes, size_t cont, FILE *arg); 


onde: 

mem representa a variável que vai receber o conteúdo lido do arquivo; 

gtd bytes representa o tamanho do bloco, em bytes, que será lido do arquivo; 

cont representa o número de blocos (do tamanho especificado pelo parâmetro gtd bytes) que serão 
lidos; 

arg é a referência para o arquivo que será lido. 


Quando a função fread() for bem-sucedida, gerará como retorno um valor igual ao número de leituras 
realizadas (igual ao parâmetro cont informado). Caso contrário, quando ocorrer algum erro ou quando o 
final do arquivo for encontrado, o valor retornado será menor que cont. 

O exemplo a seguir ilustra a utilização da função fread() (a numeração à esquerda das linhas não faz 
parte do programa). 


1. finclude <stdio.h> 

2. int main() 

3. { FILE *cli; 

4. struct cliente 

5 { int numero; 

6 char nome[20]; 

7 +; 

8 struct cliente c; 

9. cli = fopen(“c:lVexemplolitesteliclientes.dat”, “a+"); 
10. if (cli == NULL) 

11. printf(“inErro na abertura do arquivo”); 

12. else 

13. (4 fread(&c, sizeof(struct cliente), 1, cli); 

14. if (ferror(cli)) 

Us) printf(“inErro na leitura “); 

16. else printf(“inLeitura realizada com sucesso “); 
17. while (!feof(cli)) 

18. { printf (“inNúmero do cliente lido: 3d”, c.numero); 
Sa printf (“inNome do cliente lido: %s”, c.nome); 
20. fread(&c, sizeof(struct cliente), 1, cli); 

Ailo if (ferror(cli)) 

22. printf(“AnErro na leitura “); 

23. else printf(“inLeitura realizada com sucesso “); 
24. } 

Dido fclose(cli); 

26. 3 


27. getchar(); 
28. return 0; 
29.5) 
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Nesse exemplo, foi descrito como fazer leituras de dados do tipo struct cliente. Esse tipo foi definido 
na struct da linha 4 à 7. É possível observar que, nessa struct, existem dois campos, numero e nome. Na 
linha 13, foi feita a primeira leitura no arquivo, por intermédio da função fread(). A linha 14 utilizou a 
função ferror() para verificar se a leitura ocorreu corretamente. Na linha 17, foi iniciada uma estrutura de 
repetição que possibilitou que todos os dados do arquivo fossem lidos. A cada leitura realizada, os valores 
recebidos do arquivo foram armazenados na variável c. Nas linhas 18 e 19, o conteúdo dos dois campos 
da variável c foi mostrado. A repetição terminou quando foi detectado o fim do arquivo. Isso foi feito na 
linha 17, por meio da função feof(), que será apresentada em detalhes na Seção 11.3.11. Na linha 25, o 
arquivo foi fechado. 


Os quatro parâmetros utilizados na função fread() significam: 

sc — variável que receberá os dados lidos do arquivo; 

sizeof(struct cliente) — tamanho do bloco de leitura, ou seja, o tamanho em bytes ocupado por 
variáveis do tipo struct cliente; 

1 — quantidade de blocos do tamanho de sizeof(struct cliente) que serão lidos. 

cli — referência para o arquivo onde será feita a leitura. 


11.3.11 Encontrando o fim de um arquivo 


A função feof() descobre se o fim do arquivo foi encontrado. A função feof() retorna um número 
inteiro. Quando esse número for zero significa que o fim do arquivo ainda não foi atingido. Qualquer outro 
valor significa que o fim do arquivo foi encontrado. O protótipo correto dessa função é: 


int feof(FILE *arg); 


onde: 
arg é a referência para o arquivo a ser analisado. 


11.3.12 Voltando o cursor ao Início do arquivo 


O cursor é um ponteiro que indica a partir de que posição, dentro de um arquivo, uma operação será exe- 
cutada. Por exemplo, quando um arquivo acaba de ser aberto, seu cursor está apontando para a posição zero, 
ou seja, o cursor está apontando para o primeiro byte do arquivo. Caso seja feita uma leitura com o comando 
fread(), O cursor se movimentará quantos bytes forem lidos. 

A função rewind() reposiciona o cursor de volta ao início do arquivo. O protótipo dessa função é: 


void rewind(FILE *arqg); 


Exemplo: 

1. finclude <stdio.h> 

2. int main() 

3. { FILE *cli; 

4. struct cliente 

Do { int numero; 

6. char nome[20]; 

7. +; 

8. struct cliente c; 

9. cli = fopen(“c:lVexemplolitesteliclientes.dat”, “a+"); 
10. if (cli == NULL) 

11. printf(“inErro na abertura do arquivo”); 

12. else 

13. (4 fread(&c, sizeof(struct cliente), 1, cli); 

14. if (ferror(cli)) 

15 printf (“inErro na leitura “); 

16. else { 

IFES printf( “\nLeitura realizada com sucesso “); 
18. printf (”“\nNúmero do cliente: 2d”, c.numero); 
19. printf(“inNome do cliente: %s”, c.nome); 


20. rewind(cli); 
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Dil printf (“inCursor reposicionado no início”); 
22. fread(&c, sizeof(struct cliente), 1, cli); 

Do if (ferror(cli)) 

24. printf(“inErro na leitura “); 

25% else 

26. { printf(“\nLeitura realizada com sucesso “); 
Pla printf (“inNúmero do cliente: 3d”, c.numero); 
28. printf (“inNome do cliente: 3%s”, c.nome); 

29. } 

30. } 

Bilo fclose(cli); 

32e y 


33. getchar(); 
34. return 0; 
So) 


Na linha 9, o arquivo clientes. dat foi aberto e seu endereço foi atribuído à variável cli. Nesse mo- 
mento, o cursor do arquivo posicionou-se no byte zero do arquivo, início dos dados. Na linha 13 foi feita 
uma leitura no arquivo pela função fread(). Nessa leitura, foram percorridos sizeof(struct cliente) 
bytes. Isso fez com que o cursor do arquivo fosse movimentado essa mesma quantidade de bytes. 

Por exemplo: como a variável do tipo struct cliente ocupa 22 bytes (2 bytes para o numero mais um 
byte para cada posição de nome), o cursor sairá da posição zero e irá até a posição 21. 

Nas linhas 18 e 19, foi mostrado o conteúdo lido do arquivo, que foi armazenado na variável c. Na 
linha 20, a função rewind() fez o cursor voltar para a posição zero. Dessa forma, quando a função fre- 
ad(), da linha 22, foi executada, leu novamente os dados do início do arquivo. Após cada leitura, a função 
ferror() foi executada para verificar se ocorreu algum erro. Na linha 31, o arquivo foi fechado. 


11.3.13 Reposicionando o cursor de um arquivo 


O cursor é um ponteiro que indica a partir de que posição, dentro de um arquivo, uma operação será 
executada. Por exemplo, quando um arquivo acaba de ser aberto, seu cursor está apontando para a posição 
zero, ou seja, onde está o primeiro byte do arquivo. Caso seja feita uma leitura com o comando fread(), 
o cursor se movimentará tantos bytes quantos forem lidos. 

A função fseek() é utilizada especialmente para mudar a posição do cursor sem que haja necessidade 
de leituras ou escritas no arquivo. À sintaxe correta dessa função é: 


fseek(FILE *arqg, long qgtd bytes, int posicao); 


onde: 

arq representa o arquivo que será percorrido pela função fseek; 

atd bytes representa a quantidade de bytes que o cursor será movimentado a partir de posicao; 
posicao representa o ponto a partir do qual a movimentação será executada, podendo assumir três 
valores: SEEK SET, SEEK CUR, SEEK END; 

SEEK SET — permite a movimentação de gtd bytes a partir da posição inicial do arquivo; 

SEEK CUR — permite a movimentação de gtd bytes no arquivo a partir do ponto atual do cursor; 
SEEK END — permite a movimentação de gtd bytes a partir da posição final do arquivo. 


Exemplo 1: 


fseek(cli, sizeof(struct cliente) * 2, SEEK SET); 


Nesse exemplo, o cursor será movimentado a partir do início em direção ao fim do arquivo. O total 
de bytes movimentado é a quantidade de bytes necessários para armazenar uma variável do tipo struct 
cliente multiplicado por 2. 


Exemplo 2: 


fseek(cli, sizeof(struct cliente) * cont, SEEK CUR); 
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Nesse exemplo, o cursor será movimentado da posição corrente em direção ao fim do arquivo. O total 
de bytes movimentado é a quantidade de bytes necessários para armazenar uma variável do tipo struct 
cliente multiplicado pelo conteúdo da variável cont. 


Exemplo 3: 


fseek(cli, sizeof(struct cliente), SEEK END); 


Nesse exemplo, o cursor será movimentado a partir do fim em direção ao início do arquivo. O total 
de bytes movimentado é a quantidade de bytes necessários para armazenar uma variável do tipo struct 
cliente. 


11.3.14 Apagando um arquivo 
A função remove () apaga um arquivo. O protótipo dessa função é: 
int remove (char *nome arg); 
onde: 


nome arq indica o nome físico do arquivo que será removido, podendo ser incluído o ca- 
minho (path). 

Se a função remove() for executada com êxito, será devolvido o número zero. Caso contrário, será devol- 
vido qualquer outro valor. Além disso, é importante fechar o arquivo antes de removê-lo. 


Exemplo: 


remove (“c: VNexemplolNtestelNclientes.dat”); 


11.3.15 Renomeando um arquivo 
A função rename ( ) troca o nome de um arquivo. O protótipo da função rename() é: 


int rename(char *nome atual, char *nome novo); 


onde: 
nome atual indica o nome físico atual do arquivo, podendo ser incluído o caminho (path); nome novo 
indica o novo nome físico que se pretende dar ao arquivo, podendo ser incluído o caminho (path). 


Exemplo 1: 

1. finclude <stdio.h> 

2. int main() 

So (me Sep 

4. x = rename(“c: iexemplolNtesteliclientes.dat”, 
rc: NVexemplolitestelNdados.cli”); 

5. if (x == 0) 

6. printf(“Sucesso na troca de nome”); 

7. else printf(“Erro na troca de nome”); 

8. getchar(); 

9. return O; 

10.) 


No exemplo 1, o arquivo clientes.dat tem seu nome trocado para dados.cli. Observe que os ca- 
minhos (path) dos dois nomes são iguais, ou seja, será feita apenas a troca de nome, mas o arquivo perma- 
necerá no mesmo local. Além disso, a variável x guarda o resultado da execução da função rename(). Se x 
receber valor igual a zero, a troca de nome transcorreu sem problemas; caso contrário, ocorreu erro. 


Exemplo 2: 
1. finclude <stdio.h> 


2. int main() 
Do dl Jbme sen 
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4. x = rename(“c: exemplo NtestelNclientes.dat”, “c:NNatividadesiNdados.cli”); 
5. dif (x == 0) 

6. printf(“Sucesso na troca de nome”); 

7. else printf(“Erro na troca de nome”); 

8. getchar(); 

9. return O; 

10.3 


No exemplo 2, o arquivo clientes.dat tem seu nome trocado para dados.cli. Observe que os ca- 
minhos (path) dos dois nomes são diferentes, ou seja, além da troca do nome, o arquivo será removido da 
pasta C:NexemploN teste e colocado na pasta C: NNatividades. Além disso, a variável x guarda o resul- 
tado da execução da função rename(). Se x receber valor igual a zero, a troca de nome transcorreu sem 
problemas; caso contrário, ocorreu erro. 


see Observação 


E importante verificar se a pasta destino existe, porque a função rename () não consegue criar 
novas pastas. Se a pasta destino não existir a função rename() retornará um erro, ou seja, um valor 
diferente de zero. 


11.4 Trabalhando com arquivos em JAVA 


Em JAVA, é possível trabalhar com arquivos sem preocupação com o sistema operacional. O acesso a 
arquivos pode ser de baixo nível, gravando e lendo bytes, ou de nível mais alto, gravando e lendo carac- 
teres ou, ainda, gravando e lendo objetos. Arquivos texto podem ser lidos diretamente; arquivos binários 
ou contendo objetos devem ser lidos por programas especiais que convertem os dados em informações 
compreensíveis. 

Existem diversas classes em JAVA para controle da entrada e saída de arquivos, todas pertencentes 
ao pacote java. io. Como este livro é destinado a programadores iniciantes, utilizaremos as classes mais 
simples. 

Além disso, é importante saber que todas as operações envolvendo arquivos aqui descritas requerem 
a verificação de ocorrências de exceções do tipo IOException. Por essa razão, todas as linhas que mani- 
pularem arquivo devem estar dentro de blocos try-catch. Conforme mostrado a seguir (a numeração à 
esquerda não faz parte do programa). 


1. import java.io.*; 

2. public class Exemplo { 

3. public static void main(String args[]) { 

4. String cadeia; 

o try { 

6. File arq = new File(“c: VexemplolitestelNdados.txt”); 
Te if (!arq.canRead()) 

8. System.out.println(“O arquivo não pode ser lido.”); 
So else 

10. { System.out.print (“Digite seu nome: “); 

MAL FileWriter escritor = new FileWriter(arg, true); 
Ze, escritor.write(cadeia); 

1era escritor.close(); 

14. } 

155 } 


16. catch(IOException e) { 
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17. System.out.println(“Erro ao manipular arquivo.”); 
18. } 

19. 3 

20.) 


O tratamento de exceção em manipulação de arquivo é uma excelente alternativa para capturar e tratar 
problemas que independem da habilidade do programador. Por exemplo, o disco onde o arquivo está grava- 
do pode estar danificado, ou alguma outra aplicação não fechou o arquivo e seus dados foram corrompidos 
e não podem mais ser lidos etc. 

Todas as linhas escritas dentro do bloco try-catch, ou seja, da linha 5 à 15, estão sendo controladas. 
Caso algum problema relacionado a 10 (abertura, leitura, gravação e fechamento de arquivo) aconteça, a 
execução do programa é desviada para o bloco catch, que vai da linha 16 à 18. 


11.4.1 Declaração de arquivos 


A primeira classe JAVA que deve ser estudada quando se deseja trabalhar com arquivos é a File. 
Essa classe não consegue manipular o conteúdo de um arquivo por meio de leituras e gravações. Porém, 
ela fornece meios de associar uma variável a um arquivo físico, ou seja, cria um caminho abstrato entre o 
programa e o arquivo de dados. 


File arq = new File(“c:NVexemplolitestelNdados .txt”); 


No exemplo anterior, o objeto arq representa um caminho abstrato fazendo referência ao arquivo da- 
dos. txt, no caminho (path) c: exemplo Nteste. 

Por se tratar de um caminho abstrato, não é exigida a existência física desse arquivo ou diretório. Por 
isso, antes de tentar realizar qualquer operação no arquivo ou diretório, deve-se empregar outros métodos 
da classe File para algumas verificações importantes. Alguns desses métodos estão descritos a seguir. 


1) Verificando se o objeto faz referência a um arquivo ou diretório (pasta) existente 


File arq = new File(“c: WexemplolitestelNdados.txt”); 
if (arg.exists()) 
System.out.println(“Arquivo ou diretório existente.”); 
else 
System.out.println(“Caminho abstrato não existe fisicamente.”); 


2) Verificando se o objeto faz referência a um diretório (pasta) 


File arq = new File(“c: exemplolNteste”); 

if (arq.isDirectory()) 

System.out.println(“O objeto arq faz referência a um diretório."); 
else 

System.out.println(“O objeto arq não faz referência a um diretório."); 


3) Verificando se o objeto faz referência a um arquivo 


File arq = new File(“c:YVexemplolitesteldados.txt”); 

if (arg.isFile()) 

System.out.println(“O objeto arq faz referência a um arquivo existente.”); 
else 

System.out.printin(“O objeto arq faz referência a um arquivo inexistente.”"); 
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4) Verificando se o objeto faz referência a um arquivo que pode ser lido 
File arq = new File(“c: NexemplolitestelNdados.txt”); 
if (arg.canRead()) 
System.out.println(“0O arquivo pode ser lido.”); 
else 
System.out.println(“O arquivo não pode ser lido.”"); 


5) Verificando se o objeto faz referência a um arquivo que pode receber gravações 
File arq = new File(“c: IexemplolitestelNdados.txt”); 
if (arqg.canwrite()) 
System.out.println(“O arquivo pode receber gravações."); 
else 
System.out.println(“O arquivo não pode receber gravações."); 


6) Criando um novo diretório (pasta) a partir do diretório corrente 
File arg = new File(“exemplo”); 
if (arg.mkdir()) 

System.out.println(“Diretório criado com sucesso.”"); 
else 

System.out.println(“Erro na criação do diretório.”"); 


Nesse caso, será criada a pasta exemplo a partir do local onde o programa estiver gravado. 


7) Criando uma hierarquia de diretórios (pastas) 
File arq = new File(“c: NexemplolNteste”); 
if (arg.mkdirs()) 
System.out.println(“Diretório criado com sucesso."); 
else System.out.println(“Erro na criação do diretório.”); 


Nesse caso, será criada a hierarquia de pastas C :\exemplo\ teste. É necessário o uso de duplas barras 
invertidas, para impedir que sejam confundidas com caracteres especiais, como \n ou Mt, dentre outros. 


8) Alterando o nome de um arquivo 


Exemplo 1: 
File arq = new File(“c: WexemplolitestelNdados.txt”); 
File dest = new File(“c:NVexemplolNtestellarquivo.txt”); 
if (arq.renametTo (dest )) 
System.out.println(“Alteração realizada com sucesso.”"); 
else 
System.out.println(“Erro na alteração.”); 


No exemplo 1, ocorreu apenas a troca do nome do arquivo de dados .txt para arquivo.txt. Contudo, 
o arquivo permaneceu na mesma pasta (diretório). 
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Exemplo 2: 


File arq = new File(“c: NexemplolitestelNdados.txt”); 
File dest = new File(“c:NNatividadeiNtestelNarquivo.txt”); 
if (arq.renametTo (dest )) 

System.out.println(“Alteração realizada com sucesso.”); 
else 

System.out.println(“Erro na alteração.”); 


No exemplo 2, além da troca de nome do arquivo de dados. txt para arquivo.txt ocorreu, também, 
a transferência do arquivo da pasta c :\exemplo\ teste para c:Natividadelteste. É importante saber que 
o método renameTo() não tem poder para criar pastas. Assim, se a pasta (diretório) destino não existir, a 
alteração não será realizada. 


9) Descobrindo o tamanho de um arquivo 


File arq = new File(“c: NexemplolitestelNdados.txt”); 
long tamanho; 

tamanho = arg. length(); 

System.out.println(“Tamanho do arquivo = “ + tamanho); 


O método length() consegue descobrir e atribuir à variável tamanho, que é do tipo long, a quantidade 
de caracteres gravados no arquivo dados. txt. 


10) Descobrindo a hora da última atualização feita no arquivo 


File arq = new File(“c: NexemplolitestelNdados.txt”); 
long atualizacao; 
atualizacao = arq. lastModified(); 
System.out.println(“Última atualização ocorreu em = “ + atualizacao); 


O valor retornado pelo método lastModified() é um long que representa a quantidade de milissegun- 
dos existentes desde janeiro de 1970 às 00:00:00 até o momento da última atualização. 


11) Apagando um arquivo ou diretório 


Exemplo 1: 


File arq = new File(“c: WexemplolitestelNdados.txt”); 
if (arg.delete()) 

System.out.println(“Exclusão realizada com sucesso."); 
else 

System.out.println(“Erro na exclusão.”); 


No exemplo 1, o método delete() removeu do disco o arquivo chamado dados . txt, armazenado em 
c:lexemplolteste. 


Exemplo 2: 


File arq = new File(“c: VW exemplolNteste”); 
if (arg.delete()) 
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System.out.println(“Exclusão realizada com sucesso."); 
else 
System.out.println(“Erro na exclusão.”); 


No exemplo 2, o método delete() removeu do disco a pasta teste, contida em c: exemplo. 


11.4.2 Gravando caracteres em um arquivo de texto 


Depois que o programa consegue estabelecer um caminho abstrato até o arquivo de dados, outras clas- 
ses deverão ser utilizadas para a gravação e leitura. Em JAVA, a forma mais simples para isso é por meio de 
arquivos de texto, que poderão ser lidos por qualquer editor de texto. 

A classe Filewriter define objetos capazes de escrever caracteres em um arquivo. Para isso, essa classe 
coloca à disposição vários métodos. Alguns são descritos a seguir. 


1) Criando um objeto escritor 


Exemplo 1: 
File arq = new File(“c: exemplolitestelNdados.txt”); 
FileWriter escritor = new FileWwWriter(arg); 


No exemplo 1, inicialmente, foi criado o objeto arg, da classe File. Depois, foi criado o objeto escri- 
tor, vinculando-o a arg, ou seja, escritor conseguirá gravar caracteres no arquivo dados. txt. 

É importante ressaltar que, uma vez que a variável arq é do tipo File, métodos de verificação relacio- 
nados na Seção 11.4.1 poderão ser utilizados antes da realização de gravações. Isso garante mais segurança 
à aplicação. Além disso, de acordo com a forma que o objeto escritor foi criado no exemplo 1, toda vez 
que uma gravação for realizada, o conteúdo anteriormente existente no arquivo dados .txt será perdido. 


Exemplo 2: 
Filewriter escritor = new FileWriter((“c:NVexemplolitestelNdados.txt”, true); 


No exemplo 2, foi criado o objeto escritor, vinculando-o a c: NNexemploNNtesteN dados. txt, ou 
seja, escritor conseguirá gravar caracteres no arquivo dados. txt. O segundo parâmetro informado, true, 
quer dizer que será permitido o acréscimo de novos caracteres a um arquivo já existente. Se esse parâmetro 
for suprimido, toda vez que ocorrer uma gravação, os dados anteriormente existentes no arquivo serão 
destruídos. 

Como a indicação física do arquivo foi feita por meio de uma string, os métodos de verificação apre- 
sentados na Seção 11.4.1 não poderão ser utilizados. 

2) Gravando um caractere em um arquivo de texto 

char caractere = 'x'; 

File arq = new File(“c: NNexemplolitestelNdados.txt”); 

FileWriter escritor = new FileWriter (arq, true); 

escritor.write(caractere); 


Nesse exemplo, inicialmente, foi criado o objeto arg, da classe File. Depois, foi criado o objeto escri- 
tor, vinculando-o a arg, ou seja, escritor conseguirá gravar um caractere no arquivo dados . txt. O segundo 
parâmetro informado, true, quer dizer que será permitido o acréscimo de novos caracteres a um arquivo 
já existente. Se esse parâmetro for suprimido, toda vez que ocorrer uma gravação, os dados anteriormente 
existentes no arquivo serão destruídos. Por fim, o método write() do objeto escritor grava o conteúdo da 
variável caractere no arquivo dados . txt. 
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3) Acrescentando um caractere a um arquivo de texto 

char caractere = 'x'; 

File arq = new File(“c: WexemplolitestelNdados.txt”); 
FileWriter escritor = new FileWriter(arg, true); 
escritor.append (caractere); 


O método append() funciona da mesma forma que o método write() quando o parâmetro true é for- 
necido no momento da criação do objeto escritor (descrito anteriormente no item 2). 


4) Gravando uma cadeia de caracteres em um arquivo de texto 
String cadeia; 

cadeia = “exemplo de gravação”; 

File arq = new File(“c: NNexemplolMtestelNdados.txt”); 
FilewWriter escritor = new FileWriter(arqg, true); 
escritor.write(cadeia); 


Nesse exemplo, inicialmente, foi criado o objeto ara, da classe File. Depois, foi criado o objeto escritor, 
vinculando-o a arg, ou seja, escritor conseguirá gravar a cadeia de caracteres cadeia no arquivo dados . txt. 
O segundo parâmetro informado, true, quer dizer que será permitido o acréscimo de novas cadeias de carac- 
teres a um arquivo já existente. Se esse parâmetro for suprimido, toda vez que ocorrer uma gravação, os dados 
anteriormente existentes no arquivo serão destruídos. 


5) Fechando um arquivo de texto por meio do objeto de gravação 


File arq = new File(“c: NexemplolitestelNdados.txt”); 
FileWriter escritor = new FileWriter(arqg, true); 
escritor.close(); 


Nesse exemplo, o método close() fecha o arquivo dados . txt. Em outras palavras, o método close() 
interrompe a ligação entre o objeto escritor e o arquivo físico dados . txt. 

Ao término de qualquer operação, o arquivo deve ser fechado. Um arquivo fechado não permitirá a 
realização de nenhuma operação nos dados. 


11.4.3 Lendo caracteres de um arquivo de texto 


A classe rileReader define objetos capazes de ler caracteres de um arquivo. Para isso, essa classe colo- 
ca à disposição vários métodos. Alguns são descritos a seguir. 


1) Criando um objeto leitor 
Exemplo 1: 


File arq = new File(“c:YVexemplolitestelNdados.txt”); 
FileReader leitor = new FileReader (arg); 


Nesse exemplo, inicialmente, foi criado o objeto arg, da classe File. Depois, foi criado o objeto o leitor, 
vinculando-o a arg, ou seja, leitor conseguirá extrair caracteres do arquivo arq. 

É importante ressaltar que, uma vez que a variável arq é do tipo File, os métodos de verificação rela- 
cionados na Seção 11.4.1 poderão ser utilizados antes da realização de leituras. Isso garante mais segurança 
à aplicação. 
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Exemplo 2: 
FileReader leitor = new FileReader (“c: iVexemploNYtestelNdados. txt”); 


Nesse exemplo, o objeto leitor foi criado, vinculando-o a um caminho especificado, ou seja, leitor 
conseguirá extrair caracteres do arquivo dados .txt localizado em c: WWexemploWteste. 

Como a indicação física do arquivo foi feita por meio de uma string, os métodos de verificação apre- 
sentados na Seção 11.4.1 não poderão ser utilizados. 


2) Lendo um caractere do arquivo de texto 

char carac; 

File arq = new File(“c: NexemplolitestelNdados.txt”); 

FileReader leitor = new FileReader(arg); 

carac = (char)leitor.read(); 

System.out.println(“Caractere lido do arquivo texto = “ + carac); 


Nesse exemplo, inicialmente foi criado o objeto arq, da classe File. Depois, foi criado o objeto leitor, 
vinculando-o a arg, ou seja, leitor conseguirá ler um caractere do arquivo dados. txt. Por fim, o método 
read() do objeto leitor permite a leitura de um caractere do arquivo dados. txt, armazenando-o à vari- 
ável carac, que é do tipo char. 


3) Lendo uma cadeia de caracteres do arquivo de texto 

char cadeia[] = new char[5]; 

File arq = new File(“c: NNexemplolitestelNdados.txt”); 
FileReader leitor = new FileReader(arg); 

int t = leitor.read(cadeia); 


Nesse exemplo, inicialmente, foi criado objeto arg, da classe File. Depois, foi criado o objeto leitor, 
vinculando-o a arg. Assim, leitor conseguirá ler uma cadeia de caracteres de tamanho igual ao da variá- 
vel cadeia contida no arquivo dados. txt. Nesse exemplo, cadeia é um vetor de char com cinco posições, 
logo o método read(), do objeto leitor, tentará ler cinco caracteres do arquivo. A variável t receberá a 
informação de quantos caracteres realmente foram lidos. O valor máximo de t é o tamanho da cadeia. Se 
t assumir um valor menor que o tamanho da cadeia, significa que o fim do arquivo foi encontrado antes 
da cadeia estar completamente preenchida, ficando, portanto, preenchida até a posição t-1. Se t assumir 
valor -1, significa que o cursor já estava no fim do arquivo e não havia mais caracteres para leitura. 


4) Pulando caracteres em arquivo de leitura 


File arq = new File(“c: NNexemplolitestelNdados.txt”); 
FileReader leitor = new FileReader(arg); 
leitor.skip(tam); 


Nesse exemplo, o método skip() recebeu um parâmetro tam, que representa um valor inteiro corresponden- 
te à quantidade de caracteres que serão pulados dentro do arquivo de texto dados. txt. Assim, uma leitura exe- 
cutada depois dessa chamada ao método skip() conseguirá capturar os caracteres a partir da posição tam + 1. 


5) Fechando arquivo de texto por meio do objeto de leitura 
File arq = new File(“c: WexemplolitestelNdados.txt”); 
FileReader leitor = new FileReader(arg); 
leitor.close(); 
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Nesse exemplo, o método close() fecha o arquivo dados . txt. Em outras palavras, o método close() 
interrompe a ligação entre o objeto leitor e o arquivo físico dados. txt. 

Ao término de qualquer operação, o arquivo deve ser fechado. Um arquivo fechado não permitirá a 
realização de nenhuma operação nos dados. 


11.4.4 Gravando bytes em um arquivo binário 


Em JAVA, existe a possibilidade de gravar arquivos na forma binária, ou seja, os dados são convertidos 
de texto para byte e só então são gravados no arquivo de dados. 

A classe Fileoutputstream define objetos capazes de escrever bytes em um arquivo. Para isso, essa 
classe coloca à disposição vários métodos. Alguns são descritos a seguir. 


1) Criando um objeto para gravar em arquivos binários 
Exemplo 1: 


File arq = new File(“c:YVexemplolitestelNdados.txt”); 
FileOutputStream escritor = new FileOutputStream(arg); 


Nesse exemplo, inicialmente, foi criado o objeto ara, da classe File. Depois, foi criado o objeto escri- 
tor, vinculando-o a arg, ou seja, escritor conseguirá gravar bytes no arquivo dados .txt. 

É importante ressaltar que, uma vez que a variável arq é do tipo File, os métodos de verificação rela- 
cionados na Seção 11.4.1 poderão ser utilizados antes da realização de gravações. Isso garante mais segu- 
rança à aplicação. Além disso, de acordo com a forma com que o objeto escritor foi criado no exemplo 
1, toda vez que uma gravação for realizada, o conteúdo anteriormente existente no arquivo dados . txt será 
perdido. 


Exemplo 2: 


FileOutputStream escritor = new FileOutputStream(“c:VVexemplolitestelNdados.txt”,true); 


Nesse exemplo, foi criado o objeto escritor, vinculando-o a c: exemplo Ntestel dados. txt, ou seja, 
escritor conseguirá gravar caracteres no arquivo dados .txt. O segundo parâmetro informado, true, quer 
dizer que será permitido o acréscimo de novos bytes a um arquivo já existente. Se esse parâmetro for suprimi- 
do, toda vez que ocorrer uma gravação, os dados anteriormente existentes no arquivo serão destruídos. 

Como a indicação física do arquivo foi feita por meio de uma string, os métodos de verificação apre- 
sentados na Seção 11.4.1 não poderão ser utilizados. 


2) Gravando um byte em um arquivo binário 


char caractere = 'x'; 

File arq = new File(“c: NexemplolitestelNdados.txt”); 
FileOutputStream escritor = new FileOutputStream(arg); 
escritor.write(caractere) ; 


No exemplo, o método write(), do objeto escritor, consegue gravar o caractere x no arquivo dados. 
txt. É importante ressaltar que esse método deve receber como parâmetro um valor do tipo byte. Assim, no 
momento em que a variável x (do tipo char) é passada como parâmetro, acontece a conversão automática 
desse caractere para o valor ASCII equivalente. 


3) Gravando uma cadeia de bytes em um arquivo binário 

String cadeia; 

cadeia = “exemplo de gravação”; 

File arq = new File(“c: WexemplolitestelNdados.txt”); 
FileOutputStream escritor = new FileOutputStream(arg, true); 
escritor.write(cadeia.getBytes()); 
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No exemplo, o conteúdo da variável cadeia é convertido para bytes, pelo método getBytes(), e só 
depois é feita a gravação no arquivo de dados. 


Fechando um arquivo binário por meio do objeto de gravação 


File arq = new File(“c: NexemplolitestelNdados.txt”); 
FileOutputStream escritor = new FileOutputStream(arg); 


escritor.close(); 


Nesse exemplo, o método close() fecha o arquivo dados . txt. Em outras palavras, o método close() 
interrompe a ligação entre o objeto escritor e o arquivo físico dados . txt. 

Ao término de qualquer operação, o arquivo deve ser fechado. Um arquivo fechado não permitirá a 
realização de nenhuma operação nos dados. 


11.4.5 Lendo um arquivo binário 


Depois que o programa consegue estabelecer um caminho abstrato até o arquivo de dados, outras clas- 
ses deverão ser utilizadas para gravação e leitura. A leitura de dados de arquivos binários em JAVA deve ser 
feita pela classe FileInputStream. Essa classe define objetos capazes de ler bytes de um arquivo binário. 
Para isso, coloca à disposição vários métodos. Alguns são descritos a seguir. 


1) Criando um objeto para leitura de arquivo binário 
Exemplo 1: 


File arq = new File(“c: NNexemplolitestelNdados.txt”); 
FileInputStream leitor = new FileInputStream(arg); 


Nesse exemplo, inicialmente, foi criado o objeto arg, da classe File. Depois, foi criado o objeto leitor, 
vinculando-o a arq, ou seja, leitor conseguirá extrair bytes do arquivo dados . txt. 


Exemplo 2: 


FileInputStream leitor = new FileInputStream(“c:  VexemplolNtestelNdados.txt”); 


Nesse exemplo, o objeto leitor foi criado, vinculando-o a um caminho especificado, ou seja, leitor 
conseguirá extrair bytes do arquivo dados .txt localizado em c: NexemploWteste. 

Como a indicação física do arquivo foi feita por meio de uma string, os métodos de verificação apre- 
sentados na Seção 11.4.1 não poderão ser utilizados. 


2) Lendo um byte do arquivo binário 


char carac; 

File arq = new File(“c: exemplolitestelNdados.txt”); 
FileInputStream leitor = new FileInputStream(arg); 

carac = (char)leitor.read(); 

System.out.println(“Caractere lido do arquivo de texto = “ + carac); 


No exemplo, o método read() consegue capturar um byte do arquivo dados .txt. Esse byte é, então, 
convertido para o caractere correspondente na tabela ASCII, para ser guardado na variável carac. 
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3) Lendo uma cadeia de bytes do arquivo binário 

String caracteres; 

byte cadeia[] = new byte[ tamanho]; 

File arq = new File(“c: WexemplolitestelNdados.txt”); 
FileInputStream leitor = new FileInputStream(arg); 
leitor.read(cadeia); 

caracteres = new String(cadeia); 
System.out.println(“Cadeia = “ + caracteres); 


No exemplo, o método read() recebe como parâmetro a variável cadeia, que é um vetor capaz de 
guardar tamanho bytes. Isso significa que cada execução do método read() será possível capturar tamanho 
bytes do arquivo dados. txt, armazenando-os nas posições do vetor cadeia. Posteriormente, a variável 
caracteres é criada e seu conteúdo é composto pelo valor contido em cada posição do vetor cadeia, con- 
vertido para o caractere correspondente na tabela ASCII. 


4) Fechando o arquivo binário por meio do objeto de leitura 


File arq = new File(“c: NexemplolNtestelNdados.txt”); 


r 
FileInputStream leitor = new FileInputStream(arg, true); 


leitor.close(); 


Nesse exemplo, o método close() fecha o arquivo dados . txt. Em outras palavras, o método close() 
interrompe a ligação entre o objeto leitor e o arquivo físico dados . txt. 


Ao término de qualquer operação, o arquivo deve ser fechado. Um arquivo fechado não permitirá a 
realização de nenhuma operação nos dados. 


11.4.6 Trabalhando com arquivos de acesso aleatório 


Quando a quantidade de dados armazenados em um arquivo se torna grande, é necessária a utilização 
de algum mecanismo que permita acesso aleatório a determinado registro dentro do arquivo, já que a busca 
sequencial é um processo bastante lento. 

A classe RandomaccessFile permite a gravação e a recuperação de dados de um arquivo de forma ale- 
atória, colocando à disposição vários métodos. Alguns são descritos a seguir. 


1) Criando um objeto para leitura/gravação em arquivo 


Exemplo 1: 


File arq = new File(“c: NexemplolitestelNdados.txt”); 


r 
RandomAccessFile manipulador = new RandomAccessFile(arg, “rw"”); 


Nesse exemplo, inicialmente, foi criado o objeto arg, da classe File. Depois, o objeto manipulador foi 
criado, vinculando-se a arg e com permissão para leitura e gravação (“rw”), ou seja, manipulador conse- 
guirá extrair e gravar dados no arquivo arq. 


Exemplo 2: 


RandomAccessFile manipulador = new RandomAccessFile(“c: iVexemplolN testelNdados. 
= EXEC APOE 


Nesse exemplo, o objeto manipulador foi criado, vinculando-se a um caminho especificado com per- 
missão apenas para leitura (“r”), ou seja, manipulador conseguirá apenas extrair dados do arquivo dados. 
txt localizado em c:\exemplo\ teste. 
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Como foi possível observar nos dois exemplos anteriormente mostrados, toda vez que um objeto Ran- 
domaccessFile é criado, ele é vinculado a um arquivo de algum modo. Esse modo define as permissões 
que o objeto terá sobre o arquivo, tais como apenas leitura, leitura e gravação etc. A tabela a seguir mostra 
os modos de abertura possíveis. 


r Permissão apenas para leitura. 
Permissão para leitura e escrita. Se o arquivo não existir, haverá uma tentativa de 
criá-lo. 
Permissão para leitura e escrita. Se o arquivo não existir, haverá uma tentativa de 
rws criá-lo. Além disso, requer que toda atualização no conteúdo (incluindo metadados) 
seja realizada de forma síncrona, ou seja, imediatamente no arquivo. 
Permissão para leitura e escrita. Se o arquivo não existir, haverá uma tentativa de 
rwd criá-lo. Além disso, requer que toda atualização no conteúdo seja realizada de forma 
síncrona, ou seja, imediatamente no arquivo. 


2) Gravando um byte em um arquivo 

byte numero=valor; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile(arg, “rw”); 
var .writeByte (numero); 


No exemplo anterior, o método writeByte() grava o conteúdo da variável numero no arquivo dados. 
dat, utilizando a quantidade de bytes necessária ao tipo primitivo byte. 


3) Gravando um short em um arquivo 

short numero=valor; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arg, “rw"); 
var .writeShort (numero); 


No exemplo anterior, o método writeshort () grava o conteúdo da variável numero no arquivo dados. 
dat, utilizando a quantidade de bytes necessária ao tipo primitivo short. 


4) Gravando um int em um arquivo 

int numero=valor; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arg, “rw"); 
var.writeInt (numero); 


No exemplo anterior, o método writeInt() grava o conteúdo da variável numero no arquivo dados. 
dat, utilizando a quantidade de bytes necessária ao tipo primitivo int. 


5) Gravando um long em um arquivo 

long numero=valor ; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arg, “rw"); 
var.writeLong (numero); 
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No exemplo anterior, o método writeLong() grava o conteúdo da variável numero no arquivo dados. 
dat, utilizando a quantidade de bytes necessária ao tipo primitivo long. 


6) Gravando um float em um arquivo 

float numero=valor; 

File arq = new File(“c: NexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “rw”); 
var .writeFloat (numero); 


No exemplo anterior, o método writer loat () grava o conteúdo da variável numero no arquivo dados. 
dat, utilizando a quantidade de bytes necessária ao tipo primitivo float. 


7) Gravando um double em um arquivo 

double numero=valor ; 

File arq = new File(“c: NexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arg, “rw"); 
var .writeDouble (numero); 


No exemplo anterior, o método writeDouble() grava o conteúdo da variável numero no arquivo da- 
dos. dat, utilizando a quantidade de bytes necessária ao tipo primitivo double. 


8) Gravando um boolean em um arquivo 

boolean numero=valor; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “rw”); 
var.writeBoolean(numero) ; 


No exemplo anterior, o método writeBoolean() grava o conteúdo da variável numero no arquivo da- 
dos. dat, utilizando a quantidade de bytes necessária ao tipo primitivo boolean. 


9) Gravando um char em um arquivo 

char valor=valor2; 

File arq = new File(“c: NexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “rw”); 
var.writeChar (valor); 


No exemplo anterior, o método writeChar () grava o conteúdo da variável valor no arquivo dados. 
dat, utilizando a quantidade de bytes necessária ao tipo primitivo char. 


10) Gravando uma String em um arquivo 

String valor=valor2; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “rw”); 
var.writeChars (valor); 
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No exemplo anterior, o método writechars ()grava o conteúdo da variável valor no arquivo dados. 
dat, utilizando a quantidade de bytes necessária para a cadeia de caracteres armazenada na String. 


11) Gravando uma String no formato UTF-8 em um arquivo 
String valor=valor2; 

File arq = new File(“c: NNexemplolitestelNdados.txt”); 
RandomAccessFile var = new RandomAccessFile (arg, “rw"); 
var.writeUTF (valor); 


No exemplo anterior, o método writeuTr () grava o conteúdo da variável valor no arquivo dados. 
txt, utilizando a quantidade de bytes necessária para representar a cadeia de caracteres no formato UTF-8. 


QOQ Observação 


Como o tamanho de conteúdos do tipo String pode variar, ao ser executado, o método 
writeUTF() grava, primeiro, um valor numérico do tipo short (que ocupa 2 bytes), informando a 
quantidade de bytes ocupados pela String que será gravada e, só depois, grava o conteúdo da String. O 
valor numérico gravado será importante posteriormente, em operações de leitura. 


12) Lendo um byte de um arquivo 


byte numero; 

File arq = new File(”c:\\exemplo\\teste\\dados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
numero = var.readByte(); 

System.out.println(“Byte lido do arquivo = “ + numero); 


No exemplo anterior, o método readByte() percorre, no arquivo dados.dat, a quantidade de bytes 
necessários para representar o tipo primitivo byte. O conteúdo obtido é armazenado na variável numero. 


13) Lendo um short de um arquivo 


short numero; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
numero = var.readShort(); 

System.out.println(“Short lido do arquivo = “ + numero); 


No exemplo anterior, o método readShort () percorre, no arquivo dados. dat, a quantidade de bytes 
necessários para representar o tipo primitivo short. O conteúdo obtido é armazenado na variável numero. 


14) Lendo um int de um arquivo 


int numero; 

File arq = new File(“c: NNexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
numero = var.readInt(); 

System.out.println(“Int lido do arquivo = “ + numero); 


No exemplo anterior, o método readInt() percorre, no arquivo dados.dat, a quantidade de bytes 
necessários para representar o tipo primitivo int. O conteúdo obtido é armazenado na variável numero. 
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15) Lendo um long de um arquivo 

long numero; 

File arq = new File(“c: NNexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq,”r"); 
numero = var.readLong(); 

System.out.println(“Long lido do arquivo = “ + numero); 


No exemplo anterior, o método readLong() percorre, no arquivo dados.dat, a quantidade de bytes 
necessários para representar o tipo primitivo long. O conteúdo obtido é armazenado na variável numero. 


16) Lendo um float de um arquivo 


float numero; 

File arq = new File(“c: N,exemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
numero = var.readFloat(); 

System.out.println(“Float lido do arquivo = “ + numero); 


No exemplo anterior, o método readFloat () percorre, no arquivo dados. dat, a quantidade de bytes 
necessários para representar o tipo primitivo float. O conteúdo obtido é armazenado na variável numero. 


17) Lendo um double de um arquivo 


double numero; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
numero = var.readDouble(); 

System.out.println(“Double lido do arquivo = “ + numero); 


No exemplo anterior, o método readDouble() percorre, no arquivo dados. dat, a quantidade de bytes 
necessários para representar o tipo primitivo double. O conteúdo obtido é armazenado na variável numero. 


18) Lendo um boolean de um arquivo 

boolean valor; 

File arq = new File(“c: WexemplolitestelNdados.txt”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
valor = var.readBoolean(); 

System.out.println(“Boolean lido do arquivo = “ + valor); 


No exemplo anterior, o método readBoolean() percorre, no arquivo dados . dat, a quantidade de bytes 
necessários para representar o tipo primitivo boolean. O conteúdo obtido é armazenado na variável valor. 


19) Lendo um char de um arquivo 

char valor; 

File arq = new File(“c: NexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
valor = var.readChar(); 

System.out.println(“Char lido do arquivo = “ + valor); 


No exemplo anterior, o método readChar() percorre, no arquivo dados.dat, a quantidade de bytes 
necessários para representar o tipo primitivo char. O conteúdo obtido é armazenado na variável valor. 


20) Lendo uma String de um arquivo 
String valor; 
File arq = new File(“c: N,exemplolitestelNdados.dat”); 
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RandomAccessFile var = new RandomAccessFile (arq, “r"); 
valor = var.readUTF(); 
System.out.println(“String lida do arquivo = “ + valor); 


No exemplo anterior, o método readuTF() percorre, no arquivo dados.dat, a quantidade de bytes 
necessários para representar uma cadeia de caracteres no formato UTF-8. O conteúdo obtido é armazenado 
na variável valor. 


QQQ Observação 


O método readuTF () consegue apenas ler cadeias de string gravadas por meio do método wri- 
teurr(). Se a gravação foi feita pelo método writeChars (), a leitura deverá ser feita usando-se os 
recursos de leitura de arquivo de texto descrito anteriormente. 

Como o tamanho de conteúdos do tipo String pode variar, ao ser executado, o método 
readuTF () lê o conteúdo gravado nos próximos 2 bytes do arquivo, a partir da posição do atual do 
cursor. Nestes 2 bytes está gravado um valor numérico do tipo short, que indica a quantidade de 
bytes que compõem a String a ser lida. Assim, o método readuTr () sabe exatamente a quantidade 
de bytes que deverá ler para capturar a String toda. 


21) Lendo uma linha de um arquivo 

String valor; 

File arq = new File(“c: NexemplolitestelNdados.txt”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
valor = var.readLine(); 

System.out.println(“Linha lida do arquivo = “ + valor); 


No exemplo anterior, o método readLine() percorre o arquivo de texto, chamado dados .txt, da po- 
sição atual até encontrar uma marca de fim de linha ou até encontrar o fim do arquivo. O conteúdo obtido 
é armazenado na variável valor. 

O fim de um arquivo manipulado por um objeto RandomaccessFile é detectado por meio de uma 
exceção (EOFException). 


22) Descobrindo a posição do cursor no arquivo 
File arq = new File(“c: exemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile(arg, “r"); 


System.out.printin(“Posição atual do cursor = “ + var.getFilePointer()); 


No exemplo anterior, o método getFilePointer() retorna a posição corrente do cursor dentro do 
arquivo dados. dat (contada a partir do início do arquivo). 


23) Reposicionando o cursor do arquivo 

long posicao = valor; 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
arq.seek(posicao); 


No exemplo anterior, o método seek() posiciona o cursor do arquivo em determinado local. O pará- 
metro posicao determina o tamanho do deslocamento que dever ser feito, a partir do início do arquivo. 
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24) Descobrindo o tamanho do arquivo 

File arq = new File(“c: WexemplolitestelNdados.dat”); 
RandomAccessFile var = new RandomAccessFile (arq, “r"); 
System.out.println(“Tamanho do arquivo = “ + var.length()); 


No exemplo anterior, o método length () retorna o tamanho do arquivo dados. dat. 


25) Fechando um arquivo de acesso aleatório por meio do objeto de leitura/gravação 
File arq = new File(“c: NexemplolitestelNdados.dat”); 

RandomAccessFile var = new RandomAccessFile(arg, “rw”); 

var.close(); 


Nesse exemplo, o método close() fecha o arquivo dados. dat. Em outras palavras, o método close() 
interrompe a ligação entre o objeto var e o arquivo físico dados. dat. 

Ao término de qualquer operação, o arquivo deve ser fechado. Um arquivo fechado não permitirá a 
realização de nenhuma operação nos dados. 


EXERCÍCIOS RESOLVIDOS 


BEER Faça um programa para criar um arquivo chamado ALUNOS. DAT, no qual cada registro será composto 
pelos seguintes campos: numero, nome, curso, notal, nota2. 


(AILTSIOJRN ITIMO) Sorução: 


Abrir o arquivo. 


Fechar o arquivo. 


INSNI 12 SOLUÇÃO — ARQUIVO QUE TRABALHARÁ COM EXCLUSÃO FÍSICA, PORTANTO, SEM O CAMPO ATIVO: 
E \EXERC\CAP11\PASCAL\EX1_A.PAS e \EXERC\CAP11\PASCAL\EX1_A. EXE 
22 SOLUÇÃO — ARQUIVO QUE TRABALHARÁ COM EXCLUSÃO LÓGICA, PORTANTO, COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX1_B.PAS e NVEXERCACAPIINPASCALNEX1 B.EXE 


VLE Ra SoLução: 
Es! \EXERC\CAP11\C++\EX1.CPP e NEXERCACAPIINC++NEX1.EXE 


RB WIANA SoLução: 
sn! VEXERCACAPIINJAVANEX1.java e NEXERCICAPIINJAVANEXI.class 


IFA Faça um programa para incluir alunos no arquivo criado no Exercício 1, lembrando que não podem 
existir dois alunos com o mesmo número. 
(AILIGJOJRILITIM]O) SoLução: 
Os passos para a inclusão sequencial de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 
Digitar os dados que serão incluídos e fazer sua validação. 


Se o arquivo estiver vazio, gravar dados digitados no arquivo. 


450 | Fundamentos da programação de computadores 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave igual ao que se deseja incluir. 


Se encontrar o campo-chave igual ao que se deseja incluir, mostrar mensagem Re- 
gistro Duplicado. 


Se não encontrar o campo-chave igual ao que se deseja incluir, gravar dados digi- 
tados no arquivo. 


Fechar o arquivo. 


Os passos para a inclusão ordenada de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 
Digitar os dados que serão incluídos e fazer sua validação. 
Se o arquivo estiver vazio, gravar dados digitados no arquivo. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave igual ao que se deseja incluir. 


Se encontrar o campo-chave igual ao que se está querendo incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se deseja incluir, ocorrerá o desloca- 
mento de registros para gravar os dados digitados no arquivo na posição ordenada. 


Fechar o arquivo. 


iso NA 12 SOLUÇÃO — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
ERES \EXERC\CAP11\PASCAL\EX2_A.PAS e VEXERCACAPIINPASCALNEX2 A.EXE 
22 SoLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX2_B.PAS e NVEXERCACAPIINPASCALNEX2 B.EXE 


3a SoLuçÃo — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX2_C.PAS e VEXERCACAPIINPASCALNEX2 C.EXE 


42 SoLuçÃo — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


VEXERCACAPIINPASCALNEX2 D.PAS e NVEXERCACAPIINPASCALNEX2 D.EXE 
1a SoLUÇÃO — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\C++\EX2_A.CPP e \EXERC\CAP11\C++\EX2_A.EXE 
22 SoLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


\EXERC\CAP11\C++\EX2_B.CPP e VEXERCACAPIINC++HEX2 B.EXE 


3a SoLução — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


VEXERCACAP11NC++NEX2 C.CPP e VEXERCACAPIINC++HEX2 C.EXE 


42 SoLução — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


VEXERCACAP11NC++NEX2 D.CPP e \EXERC\CAP11\C++\EX2_D.EXE 

PE-N- 12 SOLUÇÃO — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
\EXERC\CAP11\JAVA\EX2_A.java e NEXERCICAPIINJAVAEX2 A.class 
22 SoLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


VEXERCACAPIINJAVAVEX2 B.java e NEXERCICAPIINJAVANEX2 B.class 


32 SoLUÇÃO — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


VEXERCACAPIINJAVAVEX2 C.java e NEXERCICAPIINJAVANEX2 C.class 


42 SoLUÇÃO — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


VEXERCACAPIINJAVANEX2 D.java e NEXERCICAPIINJAVANEX2 D.class 
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BEAR Faça um programa para alterar as notas dos alunos do arquivo criado no Exercício 1. 


(AILIGIOJRILITIMO) SoLução: 


Abrir o arquivo que sofrerá alterações. 
Digitar o campo-chave do registro que sofrerá alterações. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave que possui os dados que se deseja alterar. 


Se não encontrar o campo-chave igual ao que se deseja alterar os dados, mostrar 
mensagem. 


Se encontrar o campo-chave igual ao que se deseja alterar os dados, mostrar os 
dados do registro que sofrerá alterações, digitar e validar os novos dados, posi- 
cionar no registro que sofrerá alterações e gravar. 


Fechar o arquivo. 


iso NA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
cD \EXERC\CAP11\PASCAL\EX3_A.PAS e \EXERC\CAP11\PASCAL\EX3_A. EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX3_B.PAS e \EXERC\CAP11\PASCAL\EX3_B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\C++\EX3_A.CPP e \EXERC\CAP11\C++\EX3_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX3 B.CPP e \EXERC\CAP11\C++\EX3_B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\JAVA\EX3_A.java e \EXERC\CAP11\JAVA\EX3_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAPIINJAVANEX3 B.java e NEXERCICAPIINJAVANEX3 B.class 


EA Faça um programa para alterar o curso dos alunos do arquivo criado no Exercício 1. 


(AILISIOJRN ITIMO) Sorução: 


Abrir o arquivo que sofrerá alterações. 
Digitar o campo-chave do registro que sofrerá alterações. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave igual ao que se deseja alterar. 

Se não encontrar o campo-chave contendo os dados que se deseja alterar, mostrar 
mensagem. 

Se encontrar o campo-chave contendo os dados que se deseja alterar, mostrar os 
dados do registro que sofrerá alterações, digitar e validar os novos dados, posi- 


cionar no registro que sofrerá alterações e gravar. 


Fechar o arquivo. 
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IJ NSTo NH 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
VEXERCÂCAP11NPASCALNEX4 A.PAS e NEXERCÍCAPIINPASCALNEX4 A.EXE 

22 SOLUÇÃO — COM O CAMPO ATIVO: 

\EXERC\CAP11\PASCAL\EX4_B.PAS e NVEXERCACAPIINPASCALNEX4 B.EXE 
AVIE TSA 12 SoLução — SEM O CAMPO ATIVO: 

VEXERCACAP11NC++iEX4 A.CPP e \EXERC\CAP11\C++\EX4_A.EXE 

22 SOLUÇÃO — COM O CAMPO ATIVO: 

\EXERC\CAP11\C++\EX4_B.CPP e \EXERC\CAP11\C++\EX4_B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
NEXERCACAPIINJAVANEX4 A.java e \EXERC\CAP11\java\EX4_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
NEXERCACAPIINJAVANEX4 B.java e NEXERCACAPIINJAVANEX4 B.class 


REAR Faça um programa para excluir os alunos do arquivo criado no Exercício 1. 


(ALLISIOJRN ITIMO) Solução: 


Conforme apresentado anteriormente, existem dois tipos de exclusão: física e lógica. 
Os passos para a exclusão física de registros em um arquivo são: 


Abrir o arquivo que sofrerá exclusão. 
Digitar o campo-chave do registro que será excluído. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave que se deseja excluir. 


Se não encontrar o campo-chave que se quer excluir, mostrar mensagem. 


Se encontrar o campo-chave que se quer excluir, ocorrerá o deslocamento de regis- 
tros para sobrepor o registro que será excluído. 


Fechar o arquivo. 


Os passos para a exclusão lógica de registros em um arquivo são: 
Abrir o arquivo que sofrerá exclusão. 
Digitar o campo-chave do registro que será excluído. 
Se o arquivo estiver vazio, selecionar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave que se quer excluir. 


Se não encontrar o campo-chave que se quer excluir, mostrar mensagem. 


Se encontrar o campo-chave que se objetiva excluir, o campo de marcação (campo 
ativo) do registro será marcado como excluído. 


Fechar o arquivo. 


PINSIN 12 SOLUÇÃO — EXCLUSÃO FÍSICA —SEM O CAMPO ATIVO: 

VEXERCÂCAP11NPASCALNEX5 A.PAS e NEXERCICAPIINPASCALNEX5S A.EXE 
22 SoLUÇÃO — EXCLUSÃO LÓGICA — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX5 B.PAS e NEXERCICAPIINPASCALNEXS B.EXE 

ePAeE Ra 1º SoLução — EXCLUSÃO FÍSICA — SEM O CAMPO ATIVO: 

E 


\EXERC\CAP11\C++\EX5_A.CPP e \EXERC\CAP11\C++\EX5_A.EXE 
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24 SOLUÇÃO — EXCLUSÃO LÓGICA — COM O CAMPO ATIVO: 


VEXERCACAP11NC++NEX5 B.CPP e \EXERC\CAP11\C++\EX5_B.EXE 


—SEM O CAMPO ATIVO: 


BAIA 12 SoLução — EXCLUSÃO FÍSICA 
(EEE NEXERCACAPIINJAVANEX5S A.java e NEXERCACAPIINJAVANEX5 A.class 


22 SOLUÇÃO — EXCLUSÃO LÓGICA — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX5_B.java e NEXERCACAPIINJAVANEX5S B.class 


WA Faça um programa para consultar o número, o nome e a média de todos os alunos cadastrados no 


arquivo do Exercício 1. 


ELILOREM) SoLução: 


Os passos para a consulta geral de registros em um arquivo são: 


Abrir o arquivo que será consultado. 


Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver 


vazio, percorrer todo o arquivo, do começo ao fim, mos- 


trando todos os campos solicitados de cada um dos registros e calculando o que for 


necessário — nesse caso, 


Fechar o arquivo. 


a média. 


VO 


iso NM 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
E! \EXERC\CAP11\PASCAL\EX6_A.PAS e VEXERCACAPIINPASCALNEX6 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATI 


VO: 


\EXERC\CAP11\PASCAL\EX6_B.PAS e \EXERC\CAP11\PASCAL\EX6_B.EXE 


VO 


OVIE TSA 12 SoLução — SEM O CAMPO ATIVO: 
CEE \EXERC\CAP11\C++\EX6_A.CPP e \EXERC\CAP11\C++\EX6_A.EXE 


22 SOLUÇÃO — COM O CAMPO AT 
\EXERC\CAP11\C++\EX6 


JAVA 12 SoLução — SEM O CAMPO AT 
= \EXERC\CAP11\JAVA\EX 


22 SOLUÇÃO — COM O CAMPO AT 


\EXERC\CAP11\JAVA\EX 


VO: 


_B.CPP e \EXERC\CAP11\C++\EX6_B.EXE 


vo: 


6 A.java e VEXERCÍICAPIINJAVAVEX6 A.class 


vo: 


6 B.java e VEXERCÍICAPIINJAVAVEX6 B.class 


IEA Faça um programa para consultar o número, o nome e a média de todos os alunos cadastrados no arquivo 
do Exercício 1 e que estejam aprovados, ou seja, com média maior ou igual a 7. 


(AILTGIOJRI ITIMO) Sorução: 


Os passos para a consulta de registros em um arquivo são: 


Abrir o arquivo que será consultado. 


Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver 


vazio, percorrer todo o arquivo, do começo ao fim, cal- 


culando a média e, se esta for maior ou igual a 7, mostrando todos os campos so- 


licitados. 


Fechar o arquivo. 


INNA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\PASCAL\EX7_A.PAS e \EXERC\CAP11\PASCAL\EX7_A. EXE 
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22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAPIINPASCALNEX7 B.PAS e NVEXERCACAPIINPASCALNEX7 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\C++\EX7_A.CPP e \EXERC\CAP11\C++\EX7_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NC++NEX7 B.CPP e \EXERC\CAP11\C++\EX7_B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\JAVA\EX7_A.java e \EXERC\CAP11\JAVA\EX7_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


NEXERCACAPIINJAVANEX7 B.java e NEXERCACAPIINJAVANEX7 B.class 


REA Faça um programa para consultar o número, o nome e o curso de todos os alunos cadastrados no 
arquivo do Exercício 1 e que estejam reprovados, ou seja, com média inferior a 3. 
(ALLISIOJRN ITIMO) Solução: 
Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, calcu- 
lando a média e, se esta for menor que 3, mostrando todos os campos solicitados. 


Fechar o arquivo. 
PASCAL 12 SoLuçÃO — SEM O CAMPO ATIVO: 
Es! \EXERC\CAP11\PASCAL\EX8_A.PAS e \EXERC\CAP11\PASCAL\EX8_A. EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
\EXERC\CAP11\PASCAL\EX8_B.PAS e NVEXERCACAPIINPASCALNEX8 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\C++\EX8_A.CPP e \EXERC\CAP11\C++\EX8_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\C++\EX8_B.CPP e \EXERC\CAP11\C++\EX8_B.EXE 


BAIA 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\JAVA\EX8_A.java e \EXERC\CAP11\JAVA\EX8_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX8_B.java e \EXERC\CAP11\JAVA\EX8_B.class 


EA Faça um programa para consultar o nome de todos os alunos cadastrados no arquivo do Exercício 1 e 
que estejam de exame, ou seja, com média entre 3 (inclusive) e 7. 


(AILIGIOJRILITIM]O) SoLução: 


Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, selecionar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, cal- 
culando a média e, se esta for maior ou igual a 3 e menor que 7, mostrando todos 
os campos solicitados. 


Fechar o arquivo. 
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iso NM 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
GER \EXERC\CAP11\PASCAL\EX9_A.PAS e NEXERCACAPIINPASCALNEX9 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX9_B.PAS e NEXERCACAPI1NPASCALNEX9 B.EXE 


eJAenmM 12 SoLução — SEM O CAMPO ATIVO: 
CEND \EXERC\CAP11\C++\EX9_A.CPP e \EXERC\CAP11\C++\EX9_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
\EXERC\CAP11\C++\EX9_B.CPP e \EXERC\CAP11\C++\EX9_B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
e) NEXERCNCAP1 1NJAVANEX9 A.java e VEXERCICAPIINJAVANEX9 A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


NEXERCACAPIINJAVANEX9 B.java e NEXERCACAPIINJAVANEX9 B.class 


ELA Faça um programa para consultar o nome de todos os alunos de um curso. 
(AJLICIOJRN ITIM(O) SoLução: 


Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim. Se o 
curso gravado no arquivo for igual ao curso solicitado, mostrar todos os campos do 
registro contido no arquivo. 


Fechar o arquivo. 


INe NA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
CENE \EXERC\CAP11\PASCAL\EX10_A.PAS e \EXERC\CAP11\PASCAL\EX10_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX10 B.PAS e VEXERCICAPIINPASCALNEX10 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
e) \EXERC\CAP11\C++\EX1 O A.CPP e \EXERC\CAP11\C++\EX10_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
\EXERC\CAP11\C++\EX10_B.CPP e NEXERCACAPIINC++NEX10 B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
e) NEXERCNCAPIINJAVANEX1 O A.java e \EXERC\CAP11\JAVA\EX10_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX10_B.java e \EXERC\CAP11\JAVA\EX10_B.class 


EIR Faça um programa para criar um arquivo chamado VENDAS.DAT, em que cada registro será compos- 
to pelos seguintes campos: codigo_vendedor, nome_vendedor, valor_venda € mes. 


(AILIGIOJRI ITIMO) Solução: 


Abrir o arquivo. 


Fechar o arquivo. 


PASCAL 12 SoLuçÃO — SEM O CAMPO ATIVO: 
Es! VEXERCACAP11NPASCALNEX11 A.PAS e VEXERCICAPIINPASCALNEX11 A.EXE 
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22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAP11NPASCALNEX11 B.PAS e VEXERCICAPIINPASCALNEX11 B.EXE 


c/c++ Solução: 
D \EXERC\CAP11\C++\EX11.CPP e \EXERC\CAP11\C++\EX11.EXE 


PEGS SoLução: 
D \EXERC\CAP11\JAVA\EX11.java e \EXERC\CAP11\JAVA\EX11.class 


EPA Faça um programa para incluir um vendedor no arquivo criado no Exercício 11, lembrando que não 
podem existir dois vendedores com o mesmo código e mesmo mês de vendas. 


(ALLISIOJEN ITIM]O) Solução: 


Os passos para a inclusão sequencial de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 
Digitar os dados que serão incluídos e fazer sua validação. 
Se o arquivo estiver vazio, gravar os dados digitados nele. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar um campo-chave igual ao que se quer incluir. 


Se encontrar o campo-chave igual ao que se almeja incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se quer incluir, gravar os dados di- 
gitados no arquivo. 


Fechar o arquivo. 


Os passos para a inclusão ordenada de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 
Digitar os dados que serão incluídos e fazer sua validação. 
Se o arquivo estiver vazio, gravar os dados digitados nele. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar um campo-chave igual ao que se quer incluir. 


Se encontrar o campo-chave igual ao que se deseja incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se objetiva incluir, ocorrerá o des- 
locamento de registros para gravar os dados digitados no arquivo, na posição or- 
denada. 


Fechar o arquivo. 


I NS0 NA 12 SOLUÇÃO — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
\EXERC\CAP11\PASCAL\EX12_A.PAS e NEXERCICAPIINPASCALNEX12 A.EXE 
22 SOLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX12 B.PAS e VEXERCICAPIINPASCALNEX12 B.EXE 
32 SoLUÇÃO — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX12 C.PAS e NEXERCICAPIINPASCALNEX12 C.EXE 
42 SoLUÇÃO — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX12 D.PAS e NEXERCICAPIINPASCALNEX12 D.EXE 
eyle RM 12 SoLução — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
\EXERC\CAP11\C++\EX12_A.CPP e VEXERCACAPIINC++NEX12 A.EXE 


22 SoLução — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


VEXERCACAP11NC++iEX12 B.CPP e NEXERCACAPIINC++EX12 B.EXE 
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3a SoLução — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 

\EXERC\CAP11\C++\EX12_C.CPP e NEXERCACAPIINC++VEX12 C.EXE 

42 SoLução — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 

VEXERCACAP11NC++iEX12 D.CPP e NEXERCACAPIINC++EX12 D.EXE 

OEG 12 SOLUÇÃO — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 

VEXERCACAPIINJAVAVEX12 A.java e NEXERCICAPIINJAVANEX12 A.class 

22 SoLução — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 

VEXERCACAPIINJAVAVEX12 B.java e \EXERC\CAP11\JAVA\EX12_B.class 


3a SoLução — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


VEXERCACAPIINJAVANEX12 C.java e \EXERC\CAP11\JAVA\EX12_C.class 


42 SoLução — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX12_D.java e NEXERCICAPIINJAVANEX12 D.class 


EEA Faça um programa para alterar o valor de uma venda no arquivo criado no Exercício 11. 


(AILTSIOJRN TIM) Solução: 


Abrir o arquivo que sofrerá alterações. 
Digitar o campo-chave do registro que sofrerá alterações. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar um campo-chave igual ao que se quer alterar. 


Se não encontrar o campo-chave igual ao que se almeja alterar, mostrar mensagem. 


Se encontrar o campo-chave igual ao que se quer alterar, mostrar os dados do regis- 
tro que sofrerá alterações, digitar e validar os novos dados, posicionar no registro 
que sofrerá alterações e gravar. 


Fechar o arquivo. 


iso NA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
=! VEXERCACAP11NPASCALNEX13 A.PAS e VEXERCICAPIINPASCALNEX13 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAP11NPASCALNEX13 B.PAS e NEXERCICAPIINPASCALNEX13 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\C++\EX13_A.CPP e \EXERC\CAP11\C++\EX13_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX13 B.CPP e NEXERCACAPIINC++EX13 B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\JAVA\EX13_A.java e \EXERC\CAP11\JAVA\EX13_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAPIINJAVAVEX13 B.java e \EXERC\CAP11\JAVA\EX13_B.class 


ELA Faça um programa para excluir um vendedor no arquivo criado no Exercício 11. 
(AILTSIOJRN ITIMO) Sorução: 


Os passos para a exclusão física de registros em um arquivo são: 
Abrir o arquivo que sofrerá exclusão. 


Digitar o campo-chave do registro que será excluído. 
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Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave do registro que se quer excluir. 


Se não encontrar o campo-chave do registro que se deseja excluir, mostrar mensagem. 


Se encontrar o campo-chave do registro que se quer excluir, ocorrerá o deslocamento 
de registros para sobrepor o registro que será excluído. 


Fechar o arquivo. 


Os passos para a exclusão lógica de registros em um arquivo são: 


Abrir o arquivo que sofrerá exclusão. 
Digitar o campo-chave do registro que será excluído. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave do registro que se quer excluir. 


Se não encontrar o campo-chave do registro que se quer excluir, mostrar mensagem. 


Se encontrar o campo-chave do registro que se deseja excluir, o campo de marcação 
(campo ativo) do registro será marcado como excluído. 


Fechar o arquivo. 


12N NA 12 SOLUÇÃO — EXCLUSÃO FÍSICA —SEM O CAMPO ATIVO: 
D \EXERC\CAP11\PASCAL\EX14_A.PAS e \EXERC\CAP11\PASCAL\EX14_A. EXE 
22 SoLUÇÃO — EXCLUSÃO LÓGICA — COM O CAMPO ATIVO: 


VEXERCACAP11NPASCALNEX14 B.PAS e NEXERCICAPIINPASCALNEX14 B.EXE 
e)AeR Ha 1º SoLução — EXCLUSÃO FÍSICA — SEM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX14 A.CPP e \EXERC\CAP11\C++\EX14_A.EXE 
22 SOLUÇÃO — EXCLUSÃO LÓGICA — COM O CAMPO ATIVO: 


VEXERCACAP11NC++iEX14 B.CPP e NEXERCACAPIINC++EX14 B.EXE 
JAVA 12 SoLução — EXCLUSÃO FÍSICA — SEM O CAMPO ATIVO: 
Ea VEXERCACAPIINJAVAVEX14 A.java e \EXERC\CAP11\JAVA\EX14_A.class 


22 SOLUÇÃO — EXCLUSÃO LÓGICA — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX14_B.java e \EXERC\CAP11\JAVA\EX14_B.class 


E Faça um programa para consultar o valor da venda de um vendedor em determinado mês no arquivo 
criado no Exercício 11. 


(ALLISIOJEL TIM) Solução: 


Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, mos- 
trando todos os campos solicitados de cada um dos registros se os campos código do 
vendedor e mês forem iguais aos valores digitados. 


Fechar o arquivo. 


PASCAL 12 SoLUÇÃO — SEM O CAMPO ATIVO: 
ED \EXERC\CAP11\PASCAL\EX15_A.PAS e \EXERC\CAP11\PASCAL\EX15_A. EXE 


Capítulo 11 Arquivo | 459 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX15_B.PAS e VEXERCICAPIINPASCALNEX15 B.EXE 


Lee TSA 12 SoLução — SEM O CAMPO ATIVO: 
CD \EXERC\CAP11\C++\EX15_A.CPP e \EXERC\CAP11\C++\EX15_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\C++\EX15_B.CPP e \EXERC\CAP11\C++\EX15_B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
HEHE NEXERCICAPIINJAVANEX1I5S A.java e NEXERCACAPIINJAVANEX15 A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
\EXERC\CAP11\JAVA\EX15_B.java e \EXERC\CAP11\JAVA\EX15_B.class 


HA Faça um programa para consultar o total das vendas de determinado vendedor do arquivo criado no 
Exercício 11. 


(AJLIGIOJRILITIM]O) SoLução: 
Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, mos- 
trando todos os campos solicitados de cada um dos registros se o campo código do 
vendedor for igual ao código digitado, somando os valores das vendas para, no final 
da leitura, mostrar o total de vendas. 


Fechar o arquivo. 


INe NA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
ES VEXERCACAP11NPASCALNEX16 A.PAS e VEXERCICAPIINPASCALNEX16 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX16 B.PAS e VEXERCICAPIINPASCALNEX16 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\C++\EX16_A.CPP e \EXERC\CAP11\C++\EX16_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\C++\EX16_B.CPP e \EXERC\CAP11\C++\EX16_B.EXE 


BRAVA 12 SoLução — SEM O CAMPO ATIVO: 
E \EXERC\CAP11\JAVA\EX16_A.java e \EXERC\CAP11\JAVA\EX16_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX16_B.java e \EXERC\CAP11\JAVA\EX16_B.class 


EFA Faça um programa para consultar o nome e o código do vendedor que mais vendeu em determinado 
mês no arquivo criado no Exercício 11. 


SoLução: 
Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim. Se o 
mês da venda for igual ao digitado, conferir qual foi a maior venda (armazenando 
o nome e o código do vendedor em variáveis auxiliares). 
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Quando chegar ao final do arquivo, mostrar o nome e o código armazenados nas va- 
riáveis auxiliares. 


Fechar o arquivo. 


INNA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
cD \EXERC\CAP11\PASCAL\EX17_A.PAS e \EXERC\CAP11\PASCAL\EX17_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX17 B.PAS e VEXERCICAPIINPASCALNEX17 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
ed) \EXERC\CAP11\C++\EX1 7 A.CPP e NEXERCACAPIINC+H+HNEX17 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX17 B.CPP e NEXERCACAPIINC++VEX17 B.EXE 


BAIA 12 SoLução — SEM O CAMPO ATIVO: 
GRE! VEXERCACAPIINJAVANEX17 A.java e NEXERCICAPIINJAVANEX17 A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCÂCAPIINJAVANEX17 B.java e NEXERCICAPIINJAVANEX17 B.class 


BEAR Faça um programa para consultar no arquivo criado no Exercício 11, o mês com o maior valor de 
vendas, junto com o nome do vendedor que efetuou tais vendas. 


(ALLISIOJRN ITIMO) Solução: 


Os passos para a consulta de registros em um arquivo são: 
Abrir o arquivo que será consultado. 
Se o arquivo estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, veri- 
ficando qual a maior venda (armazenando em variáveis auxiliares a maior venda, o 
nome do vendedor responsável por ela e o mês que ocorreu). 


Quando chegar ao final do arquivo, mostrar os valores das variáveis auxiliares. 


Fechar o arquivo. 


[J Ne10 NA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
E! VEXERCACAP11NPASCALNEX18 A.PAS e VEXERCICAPIINPASCALNEX18 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX18 B.PAS e VEXERCICAPIINPASCALNEX18 B.EXE 


C/C++ 12 SoLução — SEM O CAMPO ATIVO: 
ed) \EXERC\CAP11\C++\EX1 8 A.CPP e \EXERC\CAP11\C++\EX18_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX18 B.CPP e NEXERCÍCAPIINC++EX18 B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
E \EXERC\CAP11\JAVA\EX18_A.java e \EXERC\CAP11\JAVA\EX18_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX18_B.java e \EXERC\CAP11\JAVA\EX18_B.class 
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ELJ Faça um programa para criar os arquivos a seguir. 


Cliente Conta bancária 
Número do cliente Número da conta 
Nome Número do cliente 

Saldo 


(AILTSIOTRNITIMO) Sorução: 


Abrir o arquivo (para o arquivo cliente). 
Fechar o arquivo (para o arquivo cliente). 
Abrir o arquivo (para o arquivo conta bancária). 


Fechar o arquivo (para o arquivo conta bancária). 


PASCAL ta SoLução — SEM O CAMPO ATIVO: 
cE \EXERC\CAP11\PASCAL\EX19_A.PAS e \EXERC\CAP11\PASCAL\EX19_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
\EXERC\CAP11\PASCAL\EX19_B.PAS e \EXERC\CAP11\PASCAL\EX19_B.EXE 


GVLS SoLução: 
CEE \EXERC\CAP11\C++\EX19.CPP e \EXERC\CAP11\C++\EX19.EXE 


RB WIA A SoLução: 
EEE VEXERCACAPIINJAVANEX19.java e VEXERCACAPIINJAVANEX19.class 


EIA Faça um programa que inclua clientes no arquivo criado no Exercício 19. 
SoLução: 
Os passos para a inclusão sequencial de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 
Digitar os dados que serão incluídos e fazer sua validação. 


Se o arquivo estiver vazio, gravar os dados digitados nele. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave igual ao que se quer incluir. 


Se encontrar o campo-chave igual ao que se deseja incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se quer incluir, gravar dados digita- 


dos no arquivo. 


Fechar o arquivo. 


Os passos para a inclusão ordenada de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 
Digitar os dados que serão incluídos e fazer sua validação. 
Se o arquivo estiver vazio, gravar dados digitados nele. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar o campo-chave igual ao que se deseja incluir. 


Se encontrar o campo-chave igual ao que se quer incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se deseja incluir, ocorrerá o desloca- 
mento de registros para gravar os dados digitados no arquivo, na posição ordenada. 


Fechar o arquivo. 
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VSTO NA 12 SOLUÇÃO — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
sas VEXERCACAP11NPASCALNEX20 A.PAS e VEXERCICAPIINPASCALNEX20 A.EXE 
22 SoLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX20_B.PAS e NEXERCICAPIINPASCALNEX20 B.EXE 


3a SoLução — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


NEXERCÂCAP11NPASCALNEX20 C.PAS e NEXERCICAP11NPASCALNEX20 C.EXE 


42 SOLUÇÃO — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


VEXERCACAP11NPASCALNEX20 D.PAS e VEXERCICAPIINPASCALNEX20 D.EXE 
eyle ZM 12 SoLução — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX20 A.CPP e \EXERC\CAP11\C++\EX20_A.EXE 
22 SoLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


VEXERCACAP11NC++iEX20 B.CPP e NEXERCACAPIINC++EX20 B.EXE 


32 SoLUÇÃO — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


VEXERCACAP11NC++iEX20 C.CPP e NEXERCACAPIINC++EX20 C.EXE 


42 SoLUÇÃO — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


VEXERCACAP11NC++IEX20 D.CPP e NEXERCACAPIINC++EX20 D.EXE 

BAIA 12 SoLução — INCLUSÃO SEQUENCIAL — SEM O CAMPO ATIVO: 
\EXERC\CAP11\JAVA\EX20_A.java e NEXERCICAPIINJAVANEX20 A.class 
22 SoLUÇÃO — INCLUSÃO SEQUENCIAL — COM O CAMPO ATIVO: 


VEXERCACAPIINJAVAVEX20 B.java e NEXERCICAPIINJAVANEX20 B.class 


3a SoLução — INCLUSÃO ORDENADA — SEM O CAMPO ATIVO: 


VEXERCACAPIINJAVANEX20 C.java e NEXERCICAPIINJAVANEX20 C.class 


42 SoLuçÃO — INCLUSÃO ORDENADA — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX20_D.java e \EXERC\CAP11\JAVA\EX20_D.class 


FAN Faça um programa que inclua contas para clientes já cadastrados no Exercício 20. 
(AILIGIOJRILITIM]O) SoLução: 


Os passos para a inclusão sequencial de registros em um arquivo são: 
Abrir o arquivo que sofrerá inclusões. 


Digitar os dados que serão incluídos e fazer sua validação (verificando se o clien- 
te informado foi previamente cadastrado no arquivo de clientes). 


Se o arquivo estiver vazio, gravar dados digitados nele. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 
encontrar um campo-chave igual ao que se quer incluir. 


Se encontrar o campo-chave igual ao que se quer incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se quer incluir, gravar dados digita- 
dos no arquivo. 


Fechar o arquivo. 
Os passos para a inclusão ordenada de registros em um arquivo são: 


Abrir o arquivo que sofrerá inclusões. 


Digitar os dados que serão incluídos e fazer sua validação (verificando se o clien- 
te informado foi previamente cadastrado no arquivo de clientes). 
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Se o arquivo estiver vazio, gravar dados digitados nele. 


Se o arquivo não estiver vazio, percorrer todo o arquivo, do começo ao fim, ou até 


encontrar um campo-chave igual ao que se quer incluir. 


Se encontrar o campo-chave igual ao que se deseja incluir, mostrar mensagem. 


Se não encontrar o campo-chave igual ao que se quer incluir, 


ocorrerá o desloca- 


mento de registros para gravar os dados digitados no arquivo, na posição ordenada. 


Fechar o arquivo. 


PASCAL 
=) 


C/C++ 
cD 


JAVA 
GE 


20 e21. 


12 SoLução — 
\EXERC\CAP 
2º SoLução — 
\EXERC\CAP 
32 SoLução — 
\EXERC\CAP 
42 SoLução — 
\EXERC\CAP 
12 SoLução — 
\EXERC\CAP 
22 SOLUÇÃO — 
\EXERC\CAP 
32 SOLUÇÃO — 
\EXERC\CAP 
42 Solução — 
\EXERC\CAP 
12 SoLução — 
\EXERC\CAP 
22 SOLUÇÃO — 
\EXERC\CAP 
32 SoLução — 


VEXERCACAP 


42 SoLução — 


NCL! 


USÃO SEQUENCIAL — SEM O CAMPO ATIVO: 


11\PASCAL\EX21_A.PAS e \EXERC\CAP11\PASCAL\EX21_A. EXE 


NCL! 


USÃO SEQUENCIAL — COM O CAMPO ATIVO: 


11\PASCAL\EX21_B.PAS e \EXERC\CAP11\PASCAL\EX21_B.EXE 


NCL 


USÃO ORDENADA — SEM O CAMPO ATIVO: 


11NPASCALNEX21 C.PAS e NEXERCICAP11NPASCALVEX21 C.EXE 


NCL! 


USÃO ORDENADA — COM O CAMPO ATIVO: 


11\PASCAL\EX21_D.PAS e \EXERC\CAP11\PASCAL\EX21_D.EXE 


NCL 


USÃO SEQUENCIAL — SEM O CAMPO ATIVO: 


11\C++\EX21_A.CPP e NEXERCÂCAPIINC+H+HEX21 A.EXE 


NCL 


USÃO SEQUENCIAL — COM O CAMPO ATIVO: 


11\C++\EX21_B.CPP e NEXERCÂCAPIINC++HEX21 B.EXE 


NCL 


USÃO ORDENADA — SEM O CAMPO ATIVO: 


11\C++\EX21_C.CPP e \EXERC\CAP11\C++\EX21_C.EXE 


NCL! 


USÃO ORDENADA — COM O CAMPO ATIVO: 


11\C++\EX21_D.CPP e \EXERC\CAP11\C++\EX21_D.EXE 


NCL! 


USÃO SEQUENCIAL — SEM O CAMPO ATIVO: 


11\JAVA\EX21_A.java e \EXERC\CAP11\JAVA\EX21_A.class 


NCL! 


USÃO SEQUENCIAL — COM O CAMPO ATIVO: 


11\JAVA\EX21_B.java e \EXERC\CAP11\JAVA\EX21_B.class 


NCL! 


USÃO ORDENADA — SEM O CAMPO ATIVO: 


11\JAVA\EX21_C.java e \EXERC\CAP11\JAVA\EX21_C.class 


NCL! 


USÃO ORDENADA — COM O CAMPO ATIVO: 


\EXERC\CAP11\JAVA\EX21_D.java e \EXERC\CAP11\JAVA\EX21_D.class 


(AILTSIOJRN ITIMO) Solução: 


Abrir os arquivos que sofrerão consultas. 


Digitar o código do cliente a ser consultado. 


Se o arquivo de contas não estiver vazio, percorrer todo o arquivo, 


EFA Faça um programa para consultar o saldo de todas as contas de um cliente cadastrado nos exercícios 


do começo ao 


fim, verificando se o código do cliente é igual ao código informado e, neste caso, 


mostrando os campos solicitados. 


Fechar os arquivos. 
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I Ne{eI NA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\PASCAL\EX22_A.PAS e \EXERC\CAP11\PASCAL\EX22_A. EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX22_B.PAS e \EXERC\CAP11\PASCAL\EX22_B.EXE 


AVIE TSA 12 SoLução — SEM O CAMPO ATIVO: 
Cm] \EXERC\CAP11\C++\EX2 2_A.CPP e \EXERC\CAP11\C++\EX22_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NC++iEX22 B.CPP e NEXERCACAPIINC++VEX22 B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\JAVA\EX22_A.java e \EXERC\CAP11\JAVA\EX22_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAPIINJAVAVEX22 B.java e NEXERCICAPIINJAVANEX22 B.class 


FER Faça um programa para consultar todos os clientes cujos nomes comecem por uma letra digitada pelo 
usuário juntamente com suas contas, nos arquivos criados nos exercícios 20 e 21. 


(AILIGJOJRILITIM]O) SoLução: 


Abrir os arquivos que sofrerão a consulta (clientes e contas). 
Se o arquivo clientes estiver vazio, mostrar mensagem. 


Se o arquivo de clientes não estiver vazio, percorrê-lo do início ao fim e, quando 
verificar que o nome do cliente começa com a letra digitada, mostrar seus dados e 
buscar as contas associadas ao cliente. 


Fechar os arquivos. 


INNA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\PASCAL\EX23_A.PAS e \EXERC\CAP11\PASCAL\EX23_A. EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX23_B.PAS e \EXERC\CAP11\PASCAL\EX23_B.EXE 


AVIE TSA 12 SoLução — SEM O CAMPO ATIVO: 
ed) \EXERC\CAP11\C++\EX2 3_A.CPP e \EXERC\CAP11\C++\EX23_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAP11NC++iEX23 B.CPP e NEXERCACAPIINC++EX23 B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
e) VEXERCNCAPI INJAVANEX2 3 A.java e NEXERCICAPIINJAVANEX23 A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAPIINJAVANEX23 B.java e NEXERCICAPIINJAVANEX23 B.class 


ELY Faça um programa que receba um depósito de um cliente, ou seja, atualize o saldo do cliente no arqui- 
vo criado no Exercício 21. 


(AILIGIOJRILITIM]O) SoLução: 


Abrir o arquivo que sofrerá consultas e atualizações. 
Solicitar número da conta que receberá o depósito e o valor que será depositado. 
Se o arquivo contas estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo de contas, do começo ao 
fim, verificando se o número da conta é igual ao número informado. 
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Se encontrar a conta, atualizar o saldo. Caso contrário, mostrar mensagem. 


Fechar o arquivo. 


INNA 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
ER \EXERC\CAP11\PASCAL\EX24_A.PAS e VEXERCICAPIINPASCALNEX24 A. EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
VEXERCACAP11NPASCALNEX24 B.PAS e VEXERCICAPIINPASCALNEX24 B.EXE 


VLE TSA 12 SoLução — SEM O CAMPO ATIVO: 
e) \EXERC\CAP11\C++\EX2 4 A.CPP e NVEXERCACAPIINC++HEX24 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAP11NC++iEX24 B.CPP e NEXERCÍCAPIINC++EX24 B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
CEEE \EXERC\CAP11\JAVA\EX24_A.java e NEXERCICAPIINJAVANEX24 A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


VEXERCACAPIINJAVAVEX24 B.java e NEXERCICAPIINJAVANEX24 B.class 


FER Faça um programa que receba um saque de um cliente, ou seja, atualize o saldo do cliente no arquivo 
criado no Exercício 21. 


(AILIGIOJRILITIM]O) SoLução: 


Abrir o arquivo. 
Solicitar o número da conta que receberá o saque e o valor que será sacado. 
Se o arquivo contas estiver vazio, mostrar mensagem. 


Se o arquivo não estiver vazio, percorrer todo o arquivo de contas, do começo ao 
fim, verificando se o número da conta é igual ao número informado. 


Se encontrar a conta, atualizar o saldo. Caso contrário, mostrar mensagem. 


Fechar o arquivo. 


PASCAL 12 SoLução — SEM O CAMPO ATIVO: 
e) NEXERCNCAP1 1NPASCALVEX25 A.PAS e NEXERCICAP11NPASCALNEX25 A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO: 


\EXERC\CAP11\PASCAL\EX25_B.PAS e VEXERCICAPIINPASCALNEX25 B.EXE 


PLE = 12 SOLUÇÃO — SEM O CAMPO ATIVO: 
ed) \EXERC\CAP11\C++\EX2 5 A.CPP e \EXERC\CAP11\C++\EX25_A.EXE 


22 SOLUÇÃO — COM O CAMPO ATIVO 


\EXERC\CAP11\C++\EX25_B.CPP e \EXERC\CAP11\C++\EX25_B.EXE 


JAVA 12 SoLução — SEM O CAMPO ATIVO: 
D \EXERC\CAP11\JAVA\EX25_A.java e \EXERC\CAP11\JAVA\EX25_A.class 


22 SOLUÇÃO — COM O CAMPO ATIVO: 
\EXERC\CAP11\JAVA\EX25_B.java e NEXERCICAPIINJAVANEX25 B.class 
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EXERCÍCIOS PROPOSTOS 


BEER Faça um programa para criar os arquivos a seguir: 


Clientes Recebimentos 
Cod Cli Num doc 
Nome Valor doc 
Endereco Data Emissao 
Nome Data Vencimento 
Cod Cli 


IFA Faça um programa para cadastrar clientes no arquivo criado no Exercício 1. 


IEJ Faça um programa que inclua recebimentos no arquivo criado no Exercício 1, devendo verificar se o cliente 
já se encontra cadastrado. 


IJ Faça um programa que exclua clientes e, consequentemente, todos os seus recebimentos, dos arquivos criados 
no Exercício 1. 


REA Faça um programa que altere o cadastro de clientes do Exercício 1. O usuário deve informar o código do 
cliente que será alterado. 


EA Faça um programa que altere um recebimento de um cliente, ou seja, o usuário informa o número do docu- 
mento e o número do cliente e faz as alterações desejadas. 


IEA Faça um programa que mostre todos os recebimentos com data de vencimento dentro de um período qual- 
quer. Não se esqueça de mostrar também o nome do cliente e o total de dias em atraso. Quando não houver 
atraso, mostrar zero. 


REA Faça um programa que mostre todos os recebimentos de determinado cliente. 
REA Faça um programa que mostre todos os recebimentos com valor acima de um valor dado pelo usuário. 
ELA Faça um programa que mostre todos os recebimentos com valor abaixo de um valor dado pelo usuário. 
EEE Faça um programa que mostre todos os recebimentos com valor entre dois valores dados pelo usuário. 
EFA Faça um programa para criar os arquivos a seguir: 

Estilista (código do estilista, nome do estilista, salário). 

Roupa (código da roupa, descrição da roupa, código do estilista, código da estação, ano). 

Estação (código da estação, nome da estação). 
EEJ Faça um programa para: 

Cadastrar as estações climáticas, por exemplo, primavera-verão e outono-inverno. 

Cadastrar os estilistas. 

Cadastrar as roupas. Lembre-se de que estilista e estação devem ter sido previamente cadastrados. 


Mostrar um relatório de todas as roupas de determinada estação, informando, inclusive, o nome 
do estilista que as desenhou. 


ELA Faça um programa que apresente o seguinte menu de opções: 


1. Criar 

pA Incluir 
3. Mostrar 
4. Sair 


Digite a opção desejada: 


Na opção 1: criar um arquivo com os campos: numero, nome, notal € nota2. 
Na opção 2: incluir novos registros, onde o valor de número, nome, nota1 e nota? são fornecidos pelo 
usuário (não podem ser gravados dois registros com o mesmo número). 
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Na opção 3: mostrar todos os registros cadastrados, calcular e apresentar a média das notas de cada 
registro. 


EJ Faça um programa para criar um arquivo chamado PRODUTOS. DAT, em que cada registro será composto 
pelos seguintes campos: codigo, descricao € preco. 


HA Faça um programa para incluir produtos no arquivo criado no Exercício 15, lembrando que não podem 
existir dois produtos com o mesmo código. 


ERA Faça um programa para consultar a descrição de todos os produtos que possuem preço superior a R$ 
500,00. 


EEJ Faça um programa para aumentar os preços de todos os produtos em 15%. 


EL] Faça um programa para aumentar os preços dos produtos em R$ 10,00, mas apenas daqueles que já 
custam mais de R$ 100,00. 


E Faça um programa para consultar todos os produtos cujos nomes comecem pela letra M. 
PIE Faça um programa para excluir produtos do arquivo criado no Exercício 15. 
EFA Faça um programa para consultar os produtos com preços inferiores a R$ 15,00. 


FER Faça um programa para consultar todos os produtos com nomes iniciados por uma letra digitada pelo 
usuário e com preços entre dois valores também fornecidos pelo usuário. 


EZH Faça um programa para excluir todos os produtos com preço superior a R$ 200,00. 


FER Faça um programa para conceder um percentual de desconto, informado pelo usuário, aos produtos 
cujos preços estejam entre dois valores, também informados pelo usuário. 


CAPÍTULO 


Introdução à 
] 2 programação 


orientada a objetos 


Antigamente, os programadores introduziam os programas diretamente na memória do computador e 
estes eram escritos em linguagem binária, uma linguagem pouco acessível, sem estruturação e de manuten- 
ção praticamente impossível. 

Depois, vieram as linguagens procedurais ou modulares, de mais alto nível, cujos programas pos- 
suíam uma estrutura global com instruções que eram executadas sequencialmente. Esse paradigma tra- 
balha com procedimentos, logo, a estrutura global pode ser dividida em partes menores, de mais fácil 
entendimento e manutenção. Mas, ainda assim, apresenta o problema de que os tipos de dados e os 
procedimentos ficam separados e isso exige que cada procedimento manipule corretamente os dados, ou 
seja, qualquer alteração na representação dos dados exige manutenção em todos os procedimentos que 
manipulam esses dados, tendo assim a manutenção em cascata. 

Por fim, surge o paradigma da programação orientada a objetos (POO) em que qualquer entidade tem 
características e comportamentos. Esse paradigma possui inúmeras vantagens, dentre elas destacam-se: 
reutilização de código, confiabilidade, facilidade de manutenção e extensão. 

As próximas seções apresentam uma introdução aos principais conceitos da POO e nos exemplos 
destacam-se as vantagens conseguidas com a sua utilização. O objetivo deste capítulo é fornecer o primeiro 
contato do leitor com o paradigma orientado a objetos. Para um estudo com maior profundidade, existem 
vários livros que tratam exclusivamente desses conceitos. 


12.1 Classe 


No mundo real, podemos agrupar, por exemplo, os animais. Quando realizamos esses agrupamentos, 
estamos criando CLASSES de animais, conjuntos de tipos de animais que possuem comportamentos e ca- 
racterísticas semelhantes. 


Exemplos: 


Classe mamífero 


Comportamentos: 
Produzem leite 
São endodérmicos 
Características: 
Vertebrados 
Pelos 


Classe carro 
Comportamentos: 


Gastam combustível 
Percorrem distâncias 
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Características: 
Cor 
Marca 
Modelo 


Classe funcionário 


Comportamentos: 
Recebem salários 
Recebem férias 


Recebem décimo terceiro 
Características: 


Sexo 

Salário 

Nome 

Endereço 

Data de nascimento 
Cargo 


Assim, uma classe é um tipo abstrato de dados que possui operações e características, na POO denomi- 
nadas métodos e atributos, respectivamente. 


1211 Classe em C++ 


Uma classe em C++ é uma extensão do registro (struct) em C, adicionando-se a possibilidade de definir 
componentes que são funções (métodos). A sintaxe de uma classe está descrita a seguir: 


class nome classe 


{ 
especificador de acesso: 
declaração dos atributos; 
declaração dos métodos; 

}; 

Onde: 


nome_classe: é o identificador da classe. 

especificador de acesso pode ser public, private ou protect: O public permite que atributos 
e métodos sejam acessados por qualquer classe. O private permite que atributos e métodos sejam aces- 
sados (visíveis) somente dentro da classe em que foram declarados, o que garante o encapsulamento, 
vantagem de POO descrita na Seção 12.3. Por definição padrão, os atributos e métodos são private. 
O protect funciona como o private, mas permite o acesso também pelas classes derivadas, ou seja, 
pelas denominadas subclasses. Os conceitos de subclasse e superclasse serão abordados a partir da 
Seção 12.4. Dentro de uma classe é possível ter atributos e métodos definidos com especificadores de 
acesso diferentes. 


declaração dos atributos: local onde os atributos são definidos com especificador de acesso, tipo e 
nome. 


declaração dos métodos: local onde os métodos são definidos com especificador de acesso, tipo do retor- 
no, nome e lista de parâmetros. 


470 | Fundamentos da programação de computadores 


Exemplos: 


class Produto 


{ 


// definição dos atributos valor e tipo 
// que por definição são private 

float valor; 

char tipo; 

// definição do método valorImposto 

// que por definição é private 

float valorImposto(float pre) 


}; 


class Pessoa 


{ 


// definição dos atributos nome, sexo e ano de nascimento 
// definidos no escopo public 

public: 

char nome[30]; 

char sexo; 

int ano; 

// definição do atributo salario 

// definido no escopo private 

private: 

float salario; 

// definição do método calcularAumento 
// definido no escopo private 

private: 

void calcularAumento(); 


public: 

// definição dos métodos calcularIdade e calcularFilhos 
// definidos no escopo public 

int calularIdade(int ano); 

void calcularFilhos(char sexo); 


}; 


12.1.2 Classe em JAVA 

Antes de falarmos da criação de novas classes, é importante salientar que todo programa desenvolvido 
com a linguagem JAVA, independentemente do paradigma utilizado, é escrito em uma classe. A linguagem 
JAVA possui também muitas classes internas, sendo estas compostas por vários métodos, por exemplo, a 
classe Scanner, já utilizada anteriormente neste livro. 

A sintaxe para a criação de uma classe em JAVA está descrita a seguir: 


<especificador de acesso> class nome da classe 


{ 


<especificador_de_acesso> declaração_dos_atributos; 
<especificador_de_acesso> declaração_dos_métodos; 
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Onde: 

nome da classe: é o identificador da classe. 

declaração dos atributos: local onde os atributos são definidos com especificador de acesso, tipo 
e nome. 

declaração dos métodos: local onde os métodos são definidos com especificador de acesso, tipo do 


retorno, nome e lista de parâmetros. 


O <identificador de acesso> define a visibilidade de atributos e métodos e os possíveis identifica- 
dores são: private, public e protected. O identificador private possibilita o acesso a atributos e métodos 
apenas na classe em que a mesma foi declarada. O identificador public permite o acesso de qualquer classe. 
O identificador protected tem as mesmas propriedades do identificador private, acrescentando a possibi- 
lidade de acesso pelas subclasses. 


Exemplos: 


private class Produto 


{ 


// definição dos atributos valor e tipo 
// com especificador de acesso private 
private float valor; 

private char tipo; 

// definição do método valorImposto 

// com especificador de acesso private 
private float valorImposto(float pre); 


public class Pessoa 


{ 


// definição dos atributos nome, sexo e ano de nascimento 
// com especificador de acesso public 

public String nome; 

public char sexo; 

public int ano; 

// definição dos métodos calcularIdade e calcularFilhos 
// com especificador de acesso public 

public int calularIdade(int ano); 

public void calcularFilhos (char sexo); 


}; 


12.2 Objeto 


Um objeto é um indivíduo único dentro do conjunto que é a classe. Se voltarmos aos exemplos do mun- 
do real, mencionados na Seção 12.1, é possível exemplificar um objeto da classe mamífero como a VACA 
MIMOSA, da classe carro como o GOL AZULZINHO DO MEU PAI, e da classe funcionário como JOÃO 
SILVA. Um objeto é acessado por uma variável cujo tipo é a classe a qual ele pertence. 

Quando um programa faz uso de uma variável, ela precisa ser declarada para que espaços de memória 
sejam alocados e ela seja utilizada no processamento. Com os objetos, existe essa mesma exigência. Os ob- 
jetos precisam ser declarados e instanciados para que existam e possam ser utilizados. 


12.21 Instanciando objetos em C++ 
Em C++, a sintaxe para que um objeto seja criado, ou seja, instanciado, está descrita a seguir: 


nome da classe nome do objeto; 


Exemplo: 


Produto p; 
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No exemplo anterior, um objeto denominado p, que representa um elemento da classe Produto, foi 
declarado e instanciado. 

Para acessar os atributos do objeto, é necessário seguir a sintaxe abaixo, se o atributo não tiver o es- 
pecificador de acesso private. Pois, com esse especificador, o acesso ao atributo deverá ser realizado com 
os métodos getters e setters, discutidos posteriormente na Seção 12.3, que aborda o conceito de encap- 
sulamento. 


nome do objeto.atributo 


Se desejarmos executar um método que tenha o especificador de acesso public, é necessário seguir a 
sintaxe abaixo. Caso contrário, o método será acessado diretamente pelo seu nome. 


nome do objeto.nome do método(parâmetros) 


À seguir, um programa orientado a objetos completo na linguagem C++: 
#include <stdio.h> 


class Produto 


{ 
public: 
// atributos valor e tipo 
float valor; 
char tipo; 
// método que calcula o valor do imposto 
float valorImposto() 
{ 
float i; 
if (valor < 500) 
i = valor * 10/100; 
else 
i = valor * 15/100; 
return i; 
} 
ki; 
int main() 
{ 
Produto p; 


float preco, imp; 

char tipo; 

printf(“digite o preço do produto: “); 
scanf(“3f%+*c”,&preco); 

printf(“digite o tipo do produto: “); 
scanf (“%c%*c" ,&tipo); 

p.valor = preco; 

p.tipo= tipo; 

printf(“inPreço do produto = %5.2f”,p.valor); 
printf(“inTipo do produto = 2c”,p.tipo); 
imp = p.valorImposto(); 
printf(“inImposto = 35.2f”, imp); 
getchar(); 

return 0; 
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12.2.2 Métodos construtores e destrutores em C++ 


O método construtor é executado uma única vez para cada objeto e é utilizado para reservar os espaços 
de memória de acordo com o tipo de cada atributo. Esse método pode receber parâmetros, mas não pode 
retornar valores. Quando esse método não é explicitamente definido, é executado o construtor-padrão, que 
apenas aloca espaços de memória. 

Quando o método construtor é declarado, ele deve ter o mesmo nome da classe e se torna necessário 
definir também o método destrutor, que é utilizado para liberar os espaços de memória utilizados pelos 
atributos. O método destrutor não pode possuir parâmetros e retorno e deve ter o mesmo nome da classe 
precedido pelo símbolo ~. 

À seguir, um programa orientado a objetos com o uso dos métodos construtor e destrutor na linguagem 


C++: 
#include <stdio.h> 


class Produto 
{ 
public: 
// atributos valor e tipo 
float valor; 
char tipo; 
// método construtor 
Produto() 
{ 
printf (”“\nExecutando o método construtor"); 
} 
// método destrutor 
~Produto() 
{ 
printf (”“\nExecutando o método destrutor"); 
} 
// método que calcula o valor do imposto 
float valorImposto() 
{ 
float i; 
if (valor < 500) 
i = valor * 10/100; 
else 
i = valor * 15/100; 
return i; 


}; 


int main() 
{ 

Produto p; 
float preco, imp; 
char tipo; 
printf(“\n\ndigite o preço do produto: “); 
scanf (“3f%+*c”,&preco); 
printf(“\ndigite o tipo do produto: “); 
scanf (“%c%*c" ,&tipo); 
p.valor = preco; 
p.tipo= tipo; 
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printf(“inPreço do produto = %5.2f”,p.valor); 
printf(“AnTipo do produto = 2c”,p.tipo); 

imp = p.valorImposto(); 

printf(“inImposto = 35.2f”, imp); 

getchar(); 

return 0; 


} 


A seguir, um programa orientado a objetos com o uso do método construtor com parâmetros na lin- 
guagem C++: 


#include <stdio.h> 


class Produto 
{ 
public: 
// atributos valor e tipo 
float valor; 
char tipo; 
// método construtor 
Produto(float v, char t) 
{ 
printf (”“\nExecutando o método construtor”); 
valor = v; 
tipo = t; 
k 
// método destrutor 
-Produto() 
{ 
printf (”“\nExecutando o método destrutor"); 
} 
// método que calcula o valor do imposto 
float valorImposto() 
{ 
float i; 
if (valor < 500) 
i = valor * 10/100; 
else 
i = valor * 15/100; 
return i; 


}; 


int main() 
{ 

float preco, imp; 
char tipo; 
printf(“\n\ndigite o preço do produto: “); 
scanf (“3f%+*c”,&preco); 
printf(“\ndigite o tipo do produto: “); 
scanf (“%c%*c" ,&tipo); 
Produto p(preco,tipo); 
printf(”“\nPreço do produto = %5.2f",p.valor); 
printf(“\nTipo do produto = %c",p.tipo); 
imp = p.valorImposto(); 
printf(”“\nImposto = %5.2f”"”,imp); 
getchar (); 
return 0; 
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12.2.3 Instanciando objetos em JAVA 


Em JAVA, a sintaxe para que um objeto seja criado e instanciado está descrita a seguir: 


// criando um objeto 

nome da classe nome do objeto; 

// instanciando um objeto 
nome do objeto = new nome da classe(); 


ou 


// criando e instanciando um objeto 
nome da classe nome do objeto = new nome da classe(); 


Observe nas linhas acima que, em JAVA, a instanciação não acontece simplesmente com a declaração. 
E necessária a chamada explícita ao método construtor. 


Exemplo 1: 


Produto p; 
p = new Produto(); 


No exemplo 1, a variável p é criada como uma referência ao Produto, ou seja, a variável p conterá o 
endereço de um objeto Produto. Isso significa que, logo após a declaração, o conteúdo de p é null, porque 
ela está referenciando um objeto ainda não criado. A partir da segunda linha, o conteúdo de p deixou de ser 
null e realmente passou a ser referência para um objeto Produto, ou seja, p contém o endereço inicial do 
espaço de memória ocupado por um objeto. 

Considerando que classes representam novos tipos de dados, todas as operações e declarações realiza- 
das com os tipos predefinidos da linguagem também poderão ser feitas com as classes. Dessa maneira, além 
de variáveis simples, vetores e matrizes também podem fazer uso de classes. 


Exemplo 2: 

Assim como acontece com os outros tipos de dados, uma variável pode representar um vetor ou uma 
matriz multidimensional. Para isso, será necessário: 1) criar a variável, informando que ela representará 
um vetor ou uma matriz; 2) definir o tamanho do vetor ou da matriz; 3) criar cada objeto do vetor ou da 
matriz antes de utilizá-lo. Observe o exemplo a seguir (a numeração das linhas à esquerda não faz parte do 
programa): 


1 

2. Produto exemplo[][]; 

3. exemplo = new Produto[3][6]; 

4. for(int i=0;i<3,i++) 

So for (int J=0;j<6;J++) 

6. exemplo[i][j] = new Produto(); 
7 


Em JAVA, atributos e métodos são considerados membros de classes. Para acessar um membro de 
uma classe cujo especificador de acesso é do tipo public, deve-se seguir a sintaxe adiante. Para acessar 
um membro cujo especificador de acesso é do tipo private ou protected, deverão ser utilizados os 
métodos getters e setters, discutidos posteriormente em detalhe na Seção 12.3, que aborda o conceito 
de encapsulamento. 


nome do objeto.nome do atributo 


ou 


nome do objeto.nome do método() 
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À seguir, um programa orientado a objetos completo na linguagem JAVA: 
import java.util.Scanner; 


public class Exemplo 
{ 
//Definindo a classe Produto 
private static class Produto 
{ 
public float valor; 
public String tipo; 
public float valorImposto() 
{ 
float i; 
if (valor < 500) 
i = valor * 10/100; 
else 
i = valor * 15/100; 
return i; 


public static void main(String args[]) 

{ 
Scanner dado; 
dado = new Scanner(System.in); 
Produto p = new Produto(); 
float preco, imp; 
String tipo; 
System.out.println(“digite o preço do produto: “); 
preco = dado.nextFloat(); 
System.out.println(“digite o tipo do produto: “); 
tipo = dado.next(); 
p.valor = preco; 
p.tipo= tipo; 
System.out.println(“inPreço do produto = “+p.valor); 
System.out.println(“ínTipo do produto = “+p.tipo); 
imp = p.valorImposto(); 
System.out.println(“inImposto = “+imp); 


12.2.4 Métodos construtores e destrutores em JAVA 


Método construtor é uma rotina que toda classe possui. Esse método pode estar claramente escrito 
ou não. Quando não estiver escrito, será executado o construtor-padrão, que simplesmente faz alocação 
de memória. Quando estiver escrito, deverá possuir o mesmo nome que a classe e não poderá ter tipo de 
retorno definido (nem mesmo void). Por exemplo, se quiséssemos incrementar a classe produto descrita 
anteriormente, poderíamos definir um construtor para ela. Observe como ficaria a seguir. 


Capítulo 12 


Introdução à programação orientada a objetos | 477 


import java.util.Scanner; 


public class Exemplo 
{ 
//Definindo a classe Produto 
private static class Produto 
{ 
public float valor; 
public String tipo; 
public Produto() 
{ 
valor = 0; 
tipo = Uia 
} 
public float valorImposto() 
{ 
float i; 
if (valor < 500) 
i = valor * 10/100; 
else 
i = valor * 15/100; 
return i; 


public static void main(String args[]) 


{ 


Scanner dado; 


dado = new Scanner (System.i1n); 


Produto p = new Produto(); 
float preco, imp; 
String tipo; 


System.out.println(“digite o preço do produto: “); 


preco = dado.nextFloat(); 


System.out.println(“digite o tipo do produto: 


tipo = dado.next(); 
p.valor = preco; 
p.tipo= tipo; 


Dig 


System.out.println(“inPreço do produto = “+p.valor); 
System.out.println(“ÂnTipo do produto = “+p.tipo); 


imp = p.valorImposto(); 
System.out.println(“ÀnImposto 


“+imp); 


O método construtor pode receber parâmetros. A seguir, um programa orientado a objetos com o uso 
do método construtor com parâmetros sendo utilizados para as inicializações dos atributos: 


import java.util.Scanner; 


public class Exemplo 
ł 


//Definindo a classe Produto 
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private static class Produto 


X 
public float valor; 
public String tipo; 
public Produto(float v, String t) 
{ 
valor = v; 
tipo = t; 
} 
public float valorImposto() 
{ 
float i; 
if (valor < 500) 
i = valor * 10/100; 
else 
i = valor * 15/100; 
return i; 
} 
} 
public static void main(String args[]) 
{ 
Scanner dado; 
dado = new Scanner(System.in); 
float preco, imp; 
String tipo; 
System.out.println(“digite o preço do produto: “); 
preco = dado.nextFloat(); 
System.out.println(“digite o tipo do produto: “); 
tipo = dado.next(); 
Produto p = new Produto(preco,tipo); 
System.out.println(“\nPreço do produto = “+p.valor); 
System.out.println(“\nTipo do produto = “+p.tipo); 
imp = p.valorImposto(); 
System.out.println(“inImposto = “+imp); 
+ 


12.3 Encapsulamento 


Em uma explicação literal do verbo, encapsular significa guardar algo em local fechado. Do ponto de 
vista da orientação a objetos, encapsular quer dizer ocultar todos os dados sobre um objeto, bem como 
detalhes da implementação de seus métodos. 

Porém, um objeto encapsulado precisa ser usado por diferentes aplicações. Tais aplicações podem aces- 
sar esse objeto por meio de sua interface pública. Sendo assim, se a implementação dos métodos mudar, 
as mudanças ficarão restritas a essa classe. Os métodos getters e setters representam bons exemplos dessa 
interface pública, já que centralizam os acessos aos atributos privados, ou seja, as aplicações externas não 
visualizam os atributos em si, mas, sim, os métodos públicos liberados. 

Encapsular é uma excelente estratégia para manter ocultas as regras de negócio, tornando-as visíveis 
apenas à classe responsável por elas. Contudo, ainda que as linguagens orientadas a objetos ofereçam re- 
cursos para garantir encapsulamento de objetos, seu emprego depende da compreensão de que a equipe 
de desenvolvedores possui do domínio da aplicação e da maturidade que possuem no uso do paradigma 
orientado a objetos. 
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12.3.1 Encapsulamento em C++ 


Observe a aplicação a seguir, escrita em C++. Para demonstrar o que uma classe consegue enxergar de 
outra, o exemplo apresentado a seguir é composto por três arquivos: Aluno.hpp (da linha 54 à 71), onde 
está definida a estrutura da classe, indicando os atributos, o cabeçalho dos métodos e seus respectivos espe- 
cificadores de acesso; o arquivo Aluno.cpp (da linha 21 à 53), onde estão descritas as implementações de 
cada método (declarados em Aluno. hpp) e, por fim, o arquivo Academia. cpp (da linha 1 à 20), que faz uso 
de objetos do tipo Aluno: 


Arquivo Academia.cpp 


1. finclude “Aluno.hpp” 

2. finclude <iostream> 

3. using namespace std; 

4. int main() { 

o Aluno a; 

6. string strAux; 

TE int intAux; 

8. cout << “Digite o nome do novo aluno: “; 
9. cin >> strAux; 

10. a.setNome ( strAux); 

il cout << “Digite a idade do novo aluno: “; 
T27 cin >> intAux; 

No a.setIdade (intAux) ; 

14. cout << “Ficha cadastral do novo aluno “; 
15 cout << “innome: “ << a.getNome(); 

16. cout << “inIdade: “ << a.getIdade(); 

17) 6 cout << “inData da matricula: “ << a.getDataMatricula(); 
18. cout << “inTurma: ”“ << a.getTurma(); 

19. return 0; 
Ds | 


Arquivo Aluno.cpp 


21. finclude “Aluno.hpp” 
22. #include <string> 


23. void Aluno::defineTurma() { 
24. if (idade < 18) 


25. turma = “adolescente”; 

26. else if (idade < 40) 

Ze turma = “jovem”; 

28. else if (idade < 60) 

29. turma = “adulto”; 
30. else turma = “idoso”; 
Suba De 


32. Aluno: :Aluno() { 
33. dataMatricula = DATE |; 
34. 3 


35. void Aluno::setNome(string n) { 
36. nome =n; 
Si 
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38. string Aluno: :getNome() { 
39. return nome; 
40. } 


41. void Aluno::setIdade(int i) { 


42. idade = i; 
43. defineTurma(); 
44. } 


45. int Aluno::getIdade() { 
46. return idade; 
47. } 


48. string Aluno: :getTurma() { 
49. return turma; 
50. } 


51. string Aluno: :getDataMatricula() { 
525 return dataMatricula; 
53. + 


Arquivo Aluno.hpp 


54. include <string> 
55. using namespace std; 


56. class Aluno { 


57. public: 

58. Aluno(); 

59. void setNome (string n); 
60. string getNome(); 

61. void setIdade(int idade); 
62. int getIdade(); 

63. string getTurma(); 

64. string getDataMatricula(); 
65. private: 

66. string nome; 

67. int idade; 

68. string turma; 

69. string dataMatricula; 

70. void defineTurma(); 

Lila YR 


Por simplicidade, a classe academia faz referência a apenas um objeto da classe Aluno, por meio da 
variável a. À instanciação do objeto ocorreu na linha 5. 

Vamos começar a análise da aplicação apresentada pelo arquivo Aluno .hpp, descrito da linha 54 à 71. 
Esse arquivo, por ter a extensão .hpp, poderá ser importado por todas as classes que precisarem trabalhar 
com objetos do tipo Aluno. 

No arquivo aluno.hpp definiu-se a existência de quatro atributos: nome, idade, turma € dataMatricu- 
1a. Todos foram criados usando especificador de acesso private. O uso especificador private nos atribu- 
tos é uma prática bastante recomendada, já que permite o máximo do encapsulamento, garantindo que tais 
atributos só serão acessados por linhas de código escritas dentro de uma implementação da classe aluno 
(como é o caso do arquivo Aluno.cpp). 

Contudo, observa-se que nesse arquivo não existe implementação para os métodos, que apenas são 
declarados. Da linha 58 à 64 podem ser vistas as declarações dos métodos públicos, e na linha 70 pode ser 
vista a declaração de um método privado. 
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Agora, podemos analisar o arquivo Aluno.cpp, descrito da linha 21 à 53. Esse arquivo é responsável 
por implementar todos os métodos declarados em Aluno.hpp. 

Como já mencionado, a instanciação de um objeto sempre executa o método construtor da classe. 
Nesse exemplo, o construtor da classe Aluno encontra-se implementado da linha 32 à 34. Nele, ficou es- 
tabelecido que cada vez que um novo objeto Aluno for criado, o valor do atributo dataMatricula será a 
data obtida do sistema. Ou seja, esse valor é gerado automaticamente pela aplicação, não necessitando de 
informações externas. 

Os métodos públicos permitem que, de alguma forma, dados sejam armazenados nos atributos. Caso 
contrário, eles estarão tão protegidos que ninguém poderá utilizá-los e algo que não pode ser utilizado aca- 
ba sendo inútil. Por essa razão, convencionou-se a criação de métodos getters € setters. 

Os métodos setters têm a função de receber algum dado externo e guardá-lo em um atributo. À con- 
venção de nome dos métodos setters é a palavra set seguida do nome do atributo que terá o valor atua- 
lizado. Por exemplo, o método setNome(), escrito da linha 35 à 37 recebe uma string como parâmetro, 
vindo de algum ponto externo, e a armazena no atributo nome. 

Um erro bastante comum, no entanto, é criar métodos setters para todos os atributos private. Isso 
nem sempre é necessário. Devemos criar métodos setters para aqueles atributos cujos valores dependem 
de intervenção externa. 

Observando os atributos turma e dataMatricula, percebemos que estes não possuem métodos set- 
ters, porque seus valores são definidos dentro do próprio arquivo Aluno. cpp. O valor do atributo dataMa- 
tricula é definido no método construtor, quando se obtém a data do próprio sistema. De nenhuma outra 
forma, o valor de dataMatricula será alterado. Já o valor do atributo turma é definido em função do valor 
do atributo idade. Observe que o método setIdade(), da linha 41 à 44, invoca o método defineTurma(). 
Como a ação de definir turma interessa apenas à classe Aluno, o método defineTurna(), da linha 23 à 31, 
é privado, mostrando que os métodos também podem ser protegidos ao máximo. 

Com isso, o método defineTurna() não fará parte da interface pública e, consequentente, apenas as 
linhas de código escritas dentro da própria classe Aluno.cpp poderão invocá-lo. Dessa maneira, ele poderá 
passar por qualquer tipo de alteração ou, ainda, ser removido (não esquecendo de remover sua declaração 
do arquivo Aluno.hpp), sem propagar erros para outras classes da aplicação. 

Em contrapartida, pode-se sentir necessidade de saber qual o estado de um objeto, ou seja, saber qual o 
valor de seus atributos. Quando essa necessidade existe, cria-se um método getter para cada atributo, que 
pode ter seu valor externalizado. 


12.3.2 Encapsulamento em JAVA 


Observe a aplicação a seguir, escrita em JAVA. Para demonstrar o que uma classe consegue enxergar de 
outra, o exemplo apresentado a seguir é composto por duas classes distintas, escritas em arquivos distintos 
(a numeração das linhas à esquerda foi usada apenas para facilitar a explicação). 


Arquivo Academia.java 


1. public class Academia ( 


2 public static void main(String args[]) { 

So Scanner entrada = new Scanner(System.in); 

4. Aluno a = new Aluno(); 

5. System.out.print (“Digite o nome do novo aluno: “); 
6. a.setNome (entrada.nextLine()); 

To System.out.print (“Digite a idade do novo aluno: “); 
8. a.setIdade (entrada.nextInt()); 

DE System.out.println(“Ficha cadastral do novo aluno”); 
10. System.out.println(“Nome: “ + a.getNome()); 
Ile System.out.println(“Idade: “ + a.getIdade()); 
T2 System.out.println(“Data da matrícula: “ + a.getDataMatricula()); 
SE System.out.println(“Turma: “ + a.getTurma()); 
14. } 


15. } 


482 | Fundamentos da programação de computadores 


Arquivo Aluno.java 


16. import java.util.Date; 

17. import java.text.DateFormat; 

18. import java.text.SimpleDateFormat ; 
19. public class Aluno { 


20. private String nome; 

21. private int idade; 

22. private String turma; 

Do private String dataMatricula; 

24. public Aluno() { 

257 DateFormat dateFormat = new SimpleDateFormat (“dd/MM/yyyy"); 
26. Date date = new Date(); 

27. dataMatricula = dateFormat. format (date); 
28. } 

29. public void setNome(String nome) { 

30. this.nome = nome; 

Silo } 

32. public String getNome() ( 

33. return this.nome; 

34. } 

So public void setIdade(int idade) { 

36. this.idade = idade; 

So defineTurma(); 

38. } 

39. public int getIdade() { 

40. return this.idade; 

41. } 

42. public String getTurma() { 

43. return this.turma; 

44. } 

So public String getDataMatricula() { 

46. return this.dataMatricula; 

47. } 

48. private void defineTurma() { 

49. if (this.idade < 18) 

SO) this.turma = “adolescente”; 

Sila else if (this.idade < 40) 

528 this.turma = “jovem”; 

53. else if (this.idade < 60) 

54. this.turma = “adulto”; 
557 else this.turma = “idoso”; 
56. } 
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Por simplicidade, a classe academia faz referência a apenas um objeto da classe Aluno, por meio da 
variável a. A instanciação do objeto ocorreu na linha 4. 

Vamos começar a análise da aplicação apresentada pela classe Aluno, descrita da linha 16 à 57. 

Como já mencionado, a instanciação de um objeto sempre executa o método construtor da classe. Nes- 
se exemplo, o construtor da classe Aluno está descrito da linha 24 à 28. Nele, ficou estabelecido que cada 
vez que um novo objeto Aluno for criado, o valor do atributo datamatricula será a data obtida do sistema. 
Ou seja, esse valor é gerado automaticamente pela aplicação, não necessitando de informações externas. 

A classe Aluno possui quatro atributos: nome, idade, turma e dataMatricula. Todos foram criados 
usando o especificador de acesso private. O uso do especificador private nos atributos é uma prática 
bastante recomendada, já que permite o máximo do encapsulamento, garantindo que tais atributos só serão 
acessados por linhas de código escritas dentro da própria classe Aluno. 

Contudo, é preciso que, de alguma forma, dados sejam armazenados em tais atributos. Caso contrário, 
eles estarão tão protegidos que ninguém poderá utilizá-los e algo que não pode ser utilizado acaba sendo 
inútil. Por essa razão, convencionou-se a criação de métodos getters e setters. 

Os métodos setters têm a função de receber algum dado externo e guardá-lo em um atributo. À con- 
venção de nome dos métodos setters é a palavra set seguida do nome do atributo que terá o valor atua- 
lizado. Por exemplo, o método setNome(), escrito da linha 29 à 31 recebe uma string como parâmetro, 
vindo de algum ponto externo à classe Aluno, e a armazena no atributo nome. 

Um erro bastante comum, no entanto, é criar métodos setters para todos os atributos private. Isso 
nem sempre é necessário. Devemos criar métodos setters para aqueles atributos cujos valores dependem 
de intervenção externa. 

Vamos observar os atributos turma e dataMatricula, declarados, respectivamente, nas linhas 22 e 23. 
Esses atributos não possuem métodos setters, porque seus valores são definidos pela própria classe Aluno. 
O valor do atributo dataMatricula é definido no método construtor, quando se obtém a data do próprio 
sistema. De nenhuma outra forma, o valor de dataMatricula será alterado. Já o valor do atributo turma 
é definido em função do valor do atributo idade. Observe que o método setIdade(), da linha 35 à 38, 
invoca o método defineTurma (). Como a ação de definir turma interessa apenas à classe Aluno, o método 
defineTurna(), da linha 48 à 56, é privado, mostrando que os métodos também podem ser protegidos ao 
máximo. 

Com isso, o método defineTurna() não fará parte da interface pública e, consequentemente, apenas 
as linhas de código escritas dentro da própria classe Aluno poderão invocá-lo. Dessa maneira, ele poderá 
passar por qualquer tipo de alteração ou, ainda, ser removido, sem propagar erros para outras classes da 
aplicação. 

Em contrapartida, pode-se sentir necessidade de saber qual o estado de um objeto, ou seja, saber qual o 
valor de seus atributos. Quando essa necessidade existe, cria-se um método getter para cada atributo, que 
pode ter seu valor externalizado. 


12.4 Herança 


Um dos grandes recursos proporcionados pela Orientação a Objetos é a Herança. 

A Herança tenta organizar em classes, chamadas superclasses, todos os atributos e métodos comuns a 
vários tipos de objetos. Caso alguns objetos possuam particularidades, estas deverão ser descritas em classes 
chamadas subclasses. Assim, dizemos que subclasses estendem superclasses. 

Herança permite implementar relacionamentos do tipo “é um”. Por exemplo, analisando o gráfico a 
seguir, podemos dizer que Aluno é um tipo de Pessoa e que Funcionario também é um tipo de Pessoa. Ou 
seja, tudo que está definido na classe Pessoa serve tanto para Aluno quanto para Funcionario. Porém, o 
que está definido em Aluno não serve para qualquer pessoa, assim como o que está definido em Funciona- 
rio. Por isso, dizemos que Pessoa é a superclasse (ou classe mãe) e que Aluno e Funcionario são subclasses 
(ou classes filhas). 

Tudo o que estiver definido em uma superclasse (atributos e métodos) é, automaticamente, repassado 
para as classes filhas, sem que haja necessidade de repetição de código. Essa passagem acontece como uma 
herança da vida real, em que os filhos sempre herdam algo dos pais (por exemplo: a herança genética, como 
cor dos olhos e cor dos cabelos, ou herança financeira, como bens móveis e imóveis). Herança permite de- 
finir classes em função de outras. 
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Pessoa 


Nome 
Endereco 
DataNascimento 


setNome(n) 
setEndereco(e) 
setDataNascimento(d) 
getNome():n 
getEndereco():e 
getDataNascimento():d 


Aluno Funcionario 
Curso Salario 
Semestre Cargo 
setCurso(c) setSalario(s) 
setSemestre(s) setCargo(c) 
getCurso():c getSalario():s 
fetSemestre():s getCargo():c 


Acima, temos um diagrama contendo três classes relacionadas por meio de herança. Cada caixa repre- 
senta uma classe e o triângulo representa a ocorrência da herança. A base do triângulo está sempre voltada 
para as classes filhas. 

A classe pessoa, representa o conjunto de todas as pessoas, quer sejam alunos quer funcionários. A 
classe pessoa é, portanto, a superclasse. 

A classe Aluno representa as especificidades observadas apenas em alunos. A classe Aluno é uma sub- 
classe de Pessoa. Isso quer dizer que, quando a classe Aluno for instanciada, o objeto criado conterá tudo 
o que está descrito na classe Aluno e herdará tudo o que está descrito na classe pessoa. Assim sendo, um 
aluno terá Nome, Endereço, DataNascimento, Curso € Semestre. 

A classe Funcionario representa as especificidades observadas apenas nos funcionários. A classe 
Funcionario é, portanto, uma subclasse de Pessoa. Isso quer dizer que, quando a classe Funcionario 
for instanciada, o objeto criado conterá tudo o que está descrito na classe Funcionario e herdará tudo o 
que está descrito na classe pessoa. Assim sendo, um funcionário terá Nome, Endereço, DataNascimento, 
Salario € Cargo. 

As classes Aluno e Funcionario são classes irmãs e não compartilham entre si qualquer informação. 


12.4.1 Herança em C++ 


Apresentamos, a seguir, a implementação das classes descritas do diagrama da Seção 12.4 em C++. 
Para potencializar a reutilização de código, foi criado um arquivo de cabeçalho para cada classe, sendo eles: 
Pessoa.hpp, Aluno.hpp € Funcionario.hpp. Em tais arquivos são relacionados os atributos de cada classe 
e o cabeçalho dos métodos desejados. A implementação dos métodos está descrita nos arquivos Pessoa. 
cpp, Aluno.cpp € Funcionario.cpp. Além disso, para demonstrar a utilização de tais classes, foi criado o 
arquivo Aplicacao.cpp, contendo o método main. 

A seguir está a explicação detalhada sobre cada arquivo (a numeração à esquerda das linhas foi usada 
apenas para facilitar a explicação). 

Da linha 1 à 19 está o arquivo Pessoa.hpp. Nele, estão declarados todos os atributos e métodos de 
qualquer tipo de pessoa. Observe, entretanto, que no arquivo Pessoa. hpp foram escritos apenas o cabeça- 
lho dos métodos, indicando apenas tipo de retorno, nome do método e lista de parâmetros, como pode ser 
visto da linha 11 à 17. 


Arquivo Pessoa.hpp 
1. fifndef Pessoa H 


2. fdefine Pessoa H 


3. finclude <string> 
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o Oo NoU 
O o 8) . 


19n 


. using namespace std; 


class Pessoa { 


. private: 


string nome; 
string endereco; 
string dataNascimento; 


. public: 


Pessoa(); 

string getNome(); 

void setNome (string n); 

string getEndereco(); 

void setEndereco(string e); 
string getDataNascimento(); 

void setDataNascimento (string d); 


}; 


#endif 


Da linha 20 à 43 está o arquivo Pessoa.cpp. Nele, estão as implementações dos métodos declarados 
em Pessoa.hpp. Observe que no cabeçalho de cada método, entre o tipo de retorno e o nome do método, 
está a indicação da classe que está sendo implementada. Por exemplo, void Pessoa::setNome(string n), 
escrito na linha 29, está dizendo que ali começa uma implementação do método setNome que está declarado 
em Pessoa.hpp. (Isso acontece com todos os métodos, como pode ser observado nas linhas 23, 26, 29, 32, 
35,38 e 41.) 


Arquivo Pessoa.cpp 


20. 
21. 


22. 


23. 
24. 
25 


26. 
2 
28. 


29. 
30. 
Jila 


32. 
33. 
34. 


S 5E 
36. 
37. 


include “Pessoa.hpp” 
include <iostream> 


using namespace std; 
Pessoa::Pessoa() { 


cout << “inExecutando construtor da classe Pessoa"; 


string Pessoa: :getNome() { 
return nome; 


void Pessoa: :setNome (string n) ( 
nome = n; 


string Pessoa: :getEndereco() { 
return endereco; 


void Pessoa: :setEndereco (string endereco) { 
endereco = endereco; 
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38. string Pessoa::getDataNascimento() { 
39. return dataNascimento; 
40. } 


41. void Pessoa::setDataNascimento(string d) { 
42. dataNascimento = d; 
43. } 


Da linha 44 à 60 está o arquivo Aluno.hpp. Nele, estão declarados todos os atributos e métodos de 
qualquer tipo de aluno. Observe, entretanto, que no arquivo Pessoa. hpp foram escritos apenas o cabeçalho 
dos métodos, indicando apenas tipo de retorno, nome do método e lista de parâmetros, como pode ser visto 
da linha 54 à 58. 

O relacionamento de herança, que indica que Aluno deve herdar as características de Pessoa, está defi- 
nido na linha 49, quando, após o nome da classe filha (no caso, Aluno), é colocado o nome da classe mãe. 
Para que o compilador reconhecesse a classe Pessoa, foi necessária a linha 46 (ginclude Pessoa.hpp”"). 


Arquivo Aluno.hpp 
44. #ifndef Aluno H 
45. fdefine Aluno H 


46. finclude “Pessoa.hpp” 
47. finclude <string> 
48. using namespace std; 


49. class Aluno: public Pessoa { 


50. private: 

51 string curso; 

52% string semestre; 

o public: 

54. Aluno(); 

Do string getCurso(); 

56. void setCurso(string c); 
57: string getSemestre(); 
58. void setSemestre(string sS); 
DS Jor 

60. #endif 


Da linha 61 à 78 está o arquivo Aluno. cpp. Nele, estão as implementações dos métodos declarados 
em Aluno. hpp. Observe que no cabeçalho de cada método, entre o tipo de retorno e o nome do método, 
está a indicação da classe que está sendo implementada. Por exemplo, string Aluno::getCurso(), escrito 
na linha 67, está dizendo que ali começa uma implementação do método getcurso, que está declarado em 
Aluno.hpp. (Isso acontece com todos os métodos, como pode ser observado nas linhas 64, 67, 70, 73 e 76.) 


Arquivo Aluno.cpp 


61. finclude “Aluno.hpp” 
62. finclude <iostream> 
63. using namespace std; 


64. Aluno::Aluno() { 
65. cout << “inExecutando construtor da classe Aluno”; 
66. } 


67. string Aluno: :getCurso() { 
68. return curso; 
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69. 


70. 
TAL 
T 


TOn 
74. 
75 


76. 
Tito 
78. 


void Aluno::setCurso(string c) { 
curso = c; 


string Aluno: :getSemestre() { 
return semestre; 


void Aluno::setSemestre(string s) ( 
semestre = s; 


J; 


Da linha 79 à 95 está o arquivo Funcionario .hpp. Nele, estão declarados todos os atributos e métodos 
de qualquer tipo de funcionário. Observe, entretanto, que no arquivo Funcionario .hpp foram escritos ape- 
nas o cabeçalho dos métodos, indicando apenas o tipo de retorno, nome do método e lista de parâmetros, 
como pode ser visto da linha 89 à 93. 

O relacionamento de herança, que indica que Funcionario deve herdar as características de Pessoa, 
está definido na linha 84, quando após o nome da classe filha (no caso Funcionario) é colocado o nome 
da classe mãe. Para que o compilador reconhecesse a classe Pessoa, foi necessária a linha 81 (#include 
Pessoa.hpp”). 


Arquivo Funcionario.hpp 


TIR 
80. 


81. 
82. 


83. 


84. 
85. 
86. 
87. 


88. 
89. 
90. 
oi 
ID o 
93. 
94. 


Do 


fifndef Funcionadio H 
fdefine Funcionario H 


include “Pessoa.hpp” 
include <string> 


using namespace std; 


class Funcionario: public Pessoa ( 
private: 
float salario; 
string cargo; 


public: 

Funcionario(); 

float getSalario(); 

void setSalario(float s); 
string getCargo(); 

void setCargo(string c); 


+; 


#endif 


Da linha 96 à 112 está o arquivo Funcionario.cpp. Nele, estão as implementações dos métodos 
declarados em Funcionario.hpp. Observe que no cabeçalho de cada método, entre o tipo de retor- 
no e o nome do método, está a indicação da classe que está sendo implementada. Por exemplo, float 
Funcionario: :getSalario(), escrito na linha 101, está dizendo que ali começa uma implementação do 
método getSalario que está declarado em Funcionario.hpp. (Isso acontece com todos os métodos, como 
pode ser observado nas linhas 98, 101, 104, 107 e 110.) 
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Arquivo Funcionario.cpp 


96. 
97. 


98. 
99. 
100. 


101. 
102. 
103. 


104. 
105. 
106. 


107. 
108. 
109. 


110. 
IHRE 
112. 


include “Funcionario.hpp” 


#include <iostream> 


Funcionario: :Funcionario() { 


cout 


<< “\nExecutando construtor da classe Funcionario"; 


float Funcionario: :getSalario() { 


return salario; 


void Funcionario::setSalario(float s) { 


salario = s; 


string Funcionario: :getCargo() { 


return cargo; 


void Funcionario: :setCargo(string c) { 


cargo = c; 


Da linha 113 à 156 está o arquivo Aplicacao.cpp, concebido para demonstrar a criação e utilização 
de objetos envolvidos em herança. 

Como serão usados objetos do tipo Pessoa, Aluno € Funcionário, Os respectivos arquivos com a ex- 
tensão. hpp precisaram ser incluídos, por meio das diretivas 4include, das linhas 113, 114 e 115. 


Arquivo Aplicacao.cpp 


113. 
114. 
115. 
116. 
I7 


118. 


MLS) 


120. 


12A 


122. 
123. 


124. 
2:55 


126. 
MZ The 
128. 


129. 


include 
finclude 
include 
finclude 
include 


“Pessoa.hpp” 
“Aluno.hpp” 
“Funcionario.hpp” 
<string> 
<iostream> 


using namespace std; 


int main() { 


cout << “Iniciando o processo de criação de um objeto Pessoa”; 


Pessoa p; 


cout << “ininIniciando o processo de criação de um objeto Aluno”; 


Aluno 


a; 


cout << “ininIniciando o processo de criação de um objeto Funcionario”; 


Funcionario f; 


p.setNome (“Vanderlei”); 


go] 


- SsetEndereco( “Rua 15 de novembro, 345"); 


p.setDataNascimento(“12/05/1960"); 


a.setNome(“Maria”); 
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130. a. setEndereco( “Rua 26 de agosto, 1874"); 

IRS leo a.setDataNascimento(“31/01/1990"); 

132. a.setCurso(“Ciência da Computação”); 

LIS a. setSemestre( 40"); 

134. f.setNome (“Pedro”); 

T357 f.setEndereco(“Rua 7 de setembro, 3875"); 

136. f.setDataNascimento(“27/10/1980"); 

137. f.setCargo(“Arquiteto de software”); 

138. f.setSalario(10000); 

139. cout << “inínDados cadastrados no objeto p - do tipo Pessoa”; 
140. cout << “inNome: “ << p.getNome(); 

141. cout << “inEndereço: ” << p.getEndereco(); 

142. cout << “inData de nascimento: “ << p.getDataNascimento(); 
143. cout << “\n\nDados cadastrados no objeto a - do tipo Aluno”; 
144. cout << “inNome: “ << a.getNome(); 

145. cout << “inEndereço: ”“ << a.getEndereco(); 

146. cout << “inData de nascimento: “ << a.getDataNascimento(); 
147. cout << “inCurso: “ << a.getCurso(); 

148. cout << “inSemestre: “ << a.getSemestre(); 

149. cout << “ininDados cadastrados no objeto f - do tipo Funcionario”; 
150. cout << “inNome: “ << f.getNome(); 

151. cout << “inEndereço: ” << f.getEndereco(); 

152. cout << “inData de nascimento: “ << f.getDataNascimento(); 
153% cout << “\nCargo: “ << f.getCargo(); 

154. cout << “\nSalário: R$ “ <<f.getSalario(); 

1555 return 0; 

156} 


O resultado da execução do arquivo Aplicacao.cpp é apresentado a seguir (os marcadores à esquerda 
nas linhas foram usados apenas para facilitar a explicação). 


Iniciando o processo de criação de um objeto Pessoa. 


Esta mensagem foi gerada pela execução da linha 120 do arquivo Aplicacao.cpp. 


Executando construtor da classe Pessoa. 


Esta mensagem foi gerada pela execução da linha 121 do arquivo Aplicacao.cpp, onde é criado o objeto 
p, do tipo Pessoa. Ao criar esse objeto, o construtor da classe pessoa, da linha 23 à 25, é executado. 


Iniciando o processo de criação de um objeto Aluno. 


Esta mensagem foi gerada pela execução da linha 122 do arquivo Aplicacao.cpp. 


Executando construtor da classe Pessoa. 


Executando construtor da classe Aluno. 


Estas duas mensagens foram geradas pela execução da linha 123 do arquivo Aplicacao. cpp, onde é cria- 
do o objeto a, do tipo Aluno. Como o objeto Aluno herda da classe Pessoa, ao criar o objeto a, primeiro 
foi executado o construtor da classe pessoa (da linha 23 à 25) e, depois, foi executado o construtor da 
classe Aluno (da linha 64 à 66). 
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Iniciando o processo de criação de um objeto Funcionario. 


Esta mensagem foi gerada pela execução da linha 124 do arquivo Aplicacao.cpp. 


Executando construtor da classe Pessoa. 


Executando construtor da classe Funcionario. 


Estas duas mensagens foram geradas pela execução da linha 125 do arquivo Aplicacao.cpp, onde é criado 
o objeto £, do tipo Funcionario. Como o objeto Funcionario herda da classe Pessoa, ao criar o objeto £, 
primeiro foi executado o construtor da classe pessoa (da linha 23 à 25) e, depois, foi executado o constru- 
tor da classe Funcionario (da linha 98 à 100). 


Dados cadastrados no objeto p - do tipo Pessoa. 


Esta linha foi gerada pela execução da linha 139 do arquivo Aplicacao.cpp. 


Nome: Vanderlei 
Endereço: Rua 15 de novembro, 345 


Data de nascimento: 12/05/1960 


Estas três mensagens foram geradas pela execução da linha 140 à 142 do arquivo Aplicacao.cpp, onde 
foram invocados os métodos p.getNome(), p.getEndereco(), p.getDataNascimento(). 


Dados cadastrados no objeto a — do tipo Aluno. 


Esta mensagem foi gerada pela execução da linha 143 do arquivo Aplicacao.cpp. 


Nome: Maria 

Endereço: Rua 26 de agosto, 1874 
Data de nascimento: 31/01/1990 
Curso: Ciência da Computação 


Semestre: 4º 


Estas cinco mensagens foram geradas pela execução da linha 144 à 148 do arquivo Aplicacao.cpp, 
onde foram invocados os métodos a.getNome(), a. getEndereco(), a.getDataNascimento(), que são 
métodos herdados da classe pessoa, e os métodos a .getCurso() € a. getSemestre(), que são específicos 
da classe Aluno. 


Dados cadastrados no objeto f — do tipo Funcionario. 
Esta mensagem foi gerada pela execução da linha 149 do arquivo Aplicacao.cpp. 


Nome: Pedro 

Endereço: Rua 7 de setembro, 3875 
Data de nascimento: 27/10/1980 
Cargo: Arquiteto de software 


Salário: R$ 10000 


Estas cinco mensagens foram geradas pela execução da linha 150 à 154 do arquivo Aplicacao.cpp, 
onde foram invocados os métodos £.getNome(), f.getEndereco(), f.getDataNascimento(), que são 
métodos herdados da classe Pessoa, e os métodos f.getCargo() e f.getSalario(), que são específicos 
da classe Funcionario. 
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12.4.2 Herança em JAVA 


Apresentamos, a seguir, a implementação das classes descritas do diagrama da Seção 12.4 em JAVA. 
Para potencializar a reutilização de código, foi criado um arquivo para cada classe, contendo a declaração 
dos atributos e a implementação dos métodos desejados. São eles: Pessoa. java, Aluno. java e Funciona- 
rio. java. Além disso, para demonstrar a utilização de tais classes, foi criado o arquivo Aplicacao. java, 
contendo o método main. 

A seguir, está a explicação detalhada sobre cada arquivo (a numeração à esquerda das linhas foi usada 
apenas para facilitar a explicação). 

Da linha 1 à 26 está o arquivo Pessoa. java. Nele, estão declarados todos os atributos e implementados 
todos os métodos de qualquer tipo de pessoa. 


Arquivo Pessoa.java 


1. public class Pessoa { 

2 private String nome; 

So private String endereco; 

4 private String dataNascimento; 


Do public Pessoa() { 
6 System.out.println(“Executando construtor da classe Pessoa”); 
7 } 
8. public String getNome() { 
Ss return nome; 
10. } 
JL public void setNome(String nome) { 
12. this.nome = nome; 
13. } 
14. public String getEndereco() { 
15 return endereco; 
16. } 
7a public void setEndereco(String endereco) { 
18. this.endereco = endereco; 
19. } 
20. public String getDataNascimento() { 
2 return dataNascimento; 
22. } 
23. public void setDataNascimento(String dataNascimento) { 
24. this.dataNascimento = dataNascimento; 
25. } 
26. } 


Da linha 27 à 45 está o arquivo Aluno. java. Nele, estão declarados os atributos e implementados os 
métodos que são específicos para alunos. 

O relacionamento de herança, que indica que Aluno deve herdar as características de Pessoa, está de- 
finido na linha 27, quando após o nome da classe Aluno é colocado extends Pessoa, deixando claro que 
Aluno é uma extensão de Pessoa. 
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Arquivo Aluno.java 


27. public class Aluno extends Pessoa { 


28. private String curso; 

29. private String semestre; 

30. public Aluno() { 

Sia System.out.println(“Executando construtor da classe Aluno”); 
32. } 

So public String getCurso() { 

34. return curso; 

São } 

36. public void setCurso(String curso) { 

Silo this.curso = curso; 

38. } 

SS public String getSemestre() { 

40. return semestre; 

41. } 

42. public void setSemestre(String semestre) { 
43. this.semestre = semestre; 

44. } 

45. } 


Da linha 46 à 64 está o arquivo Funcionario. java. Nele, estão declarados os atributos e implementa- 
dos os métodos que são específicos para funcionários. 

O relacionamento de herança, que indica que Funcionario deve herdar as características de Pessoa 
está definido na linha 46, quando após o nome da classe Funcionario é colocado extends Pessoa, deixan- 
do claro que Funcionario é uma extensão de Pessoa. 


Arquivo Funcionario.java 


46. public class Funcionario extends Pessoa { 


47. private float salario; 

48. private String cargo; 

49. public Funcionario() { 

So System.out.println(“Executando construtor da classe Funcionario"); 
Silo } 

52% public float getSalario() { 

53 return salario; 

54. } 

55% public void setSalario(float salario) { 
56. this.salario = salario; 

5h } 

58. public String getCargo() { 

59. return cargo; 


60. } 


Capítulo 12 Introdução à programação orientada a objetos | 493 


61. public void setCargo(String cargo) { 
62. this.cargo = cargo; 

63. } 

64. } 


Da linha 65 à 103 está o arquivo Aplicacao. java, criado para demonstrar a criação e utilização de 
objetos envolvidos em herança. 


Arquivo Aplicacao.java 


65. public class Aplicacao { 
66. public static void main(String[] args) { 


67. System.out.println(“Iniciando o processo de criação de um objeto Pessoa”); 
68. Pessoa p = new Pessoa(); 

69. System.out.println(“ÀnIniciando o processo de criação de um objeto Aluno”); 
70. Aluno a = new Aluno(); 

lo System.out.println(“ÍnIniciando o processo de criação de um objeto Funcionario”); 
J2 Funcionario f = new Funcionario(); 

73. p.setNome (“Vanderlei”); 

74. p.setEndereco (“Rua 15 de novembro, 345"); 

VD p.setDataNascimento(“12/05/1960"); 

76. a.setNome (“Maria”); 

YU a.setEndereco (“Rua 26 de agosto, 1874"); 

78. a.setDataNascimento(“31/01/1990"); 

79. a.setCurso( “Ciência da Computação”); 

80. a.setSemestre ("4º"); 

81. f.setNome (“Pedro”); 

82. f.setEndereco (“Rua 7 de setembro, 3875"); 

83. f.setDataNascimento(“27/10/1980"); 

84. f.setCargo(“Arquiteto de software”); 

85. f.setSalario( 10000); 

86. System.out.println(“inDados cadastrados no objeto p - do tipo Pessoa”); 
87. System.out.println(“Nome: “ + p.getNome()); 

88. System.out.println(“Endereço “ + p.getEndereco()); 

89. System.out.println(“Data de nascimento: “ + p.getDataNascimento()); 

90. System.out.println(“inDados cadastrados no objeto a - do tipo Aluno”); 

Silo System.out.println(“Nome: “ + a.getNome()); 

92. System.out.println(“Endereço: “ + a.getEndereco()); 

93. System.out.println(“Data de nascimento: “ + a.getDataNascimento()); 

94. System.out.println(“Curso: “ + a.getCurso()); 

95. System.out.println(“Semestre: “ + a.getSemestre()); 

96. System.out.println(“inDados cadastrados no objeto f - do tipo Funcionario"); 
97. System.out.println(“Nome: “ + f.getNome()); 

98. System.out.println(“Endereco: “ + f.getEndereço()); 


99. System.out.println(“Data de nascimento: “ + f.getDataNascimento()); 
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100. System.out.println(“Cargo: “ + f.getCargo()); 

101. System.out.println(“Salário: R$ “ + f.getSalario()); 
102. + 

Do 


O resultado da execução do arquivo Aplicacao. java está apresentado a seguir (os marcadores à es- 
querda nas linhas foram usados apenas para facilitar a explicação). 


Iniciando o processo de criação de um objeto Pessoa. 


Esta mensagem foi gerada pela execução da linha 67 do arquivo Aplicacao. java. 


Executando construtor da classe Pessoa. 


Esta mensagem foi gerada pela execução da linha 68 do arquivo Aplicacao. java, onde é criado o objeto 
p, do tipo Pessoa. Ao criar esse objeto, o construtor da classe pessoa, da linha 5 à 7, é executado. 


Iniciando o processo de criação de um objeto Aluno. 


Esta mensagem foi gerada pela execução da linha 69 do arquivo Aplicacao. java. 


Executando construtor da classe Pessoa. 


Executando construtor da classe Aluno. 


Estas duas mensagens foram geradas pela execução da linha 70 do arquivo Aplicacao. java, onde é 
criado o objeto a, do tipo Aluno. Como o objeto Aluno herda da classe Pessoa, ao criar o objeto a, pri- 
meiro foi executado o construtor da classe Pessoa (da linha 5 à 7) e, depois, foi executado o construtor 
da classe Aluno (da linha 30 à 32). 


Iniciando o processo de criação de um objeto Funcionario. 


Esta mensagem foi gerada pela execução da linha 71 do arquivo Aplicacao. java. 


Executando construtor da classe Pessoa. 


Executando construtor da classe Funcionario. 


Estas duas mensagens foram geradas pela execução da linha 72 do arquivo Aplicacao. java, onde é 
criado o objeto £, do tipo Funcionario. Como o objeto Funcionario herda da classe pessoa, ao criar o 
objeto £, primeiro foi executado o construtor da classe pessoa (da linha 5 à 7) e, depois, foi executado 
o construtor da classe Funcionario (da linha 49 à 51). 


Dados cadastrados no objeto p - do tipo Pessoa. 
Esta linha foi gerada pela execução da linha 86 do arquivo Aplicacao. java. 
Nome: Vanderlei 


Endereço: Rua 15 de novembro, 345 


Data de nascimento: 12/05/1960 


Estas três mensagens foram geradas pela execução da linha 87 à 89 do arquivo Aplicacao. java, onde 
foram invocados os métodos p.getNome(), p.getEndereco(), p.getDataNascimento(). 


Dados cadastrados no objeto a - do tipo Aluno. 


Esta mensagem foi gerada pela execução da linha 90 do arquivo Aplicacao. java. 


Nome: Maria 


Endereço: Rua 26 de agosto, 1874 
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Data de nascimento: 31/01/1990 
Curso: Ciência da Computação 


Semestre: 4º 


Estas cinco mensagens foram geradas pela execução da linha 91 à 95 do arquivo Aplicacao. java, onde 
foram invocados os métodos a.getNome(), a.getEndereco(), a.getDataNascimento(), que são méto- 
dos herdados da classe Pessoa, e os métodos a .getCurso() € a.getSemestre(), que são específicos da 
classe Aluno. 


Dados cadastrados no objeto f - do tipo Funcionario. 


Esta mensagem foi gerada pela execução da linha 96 do arquivo Aplicacao. java. 


Nome: Pedro 

Endereço: Rua 7 de setembro, 3875 
Data de nascimento: 27/10/1980 
Cargo: Arquiteto de software 


Salário: R$ 10000.0 


Estas cinco mensagens foram geradas pela execução da linha 97 à 101 do arquivo Aplicacao. java, 
onde foram invocados os métodos £.getNome (), f.getEndereco(), f.getDataNascimento(), que são 
métodos herdados da classe Pessoa, e os métodos f.getCargo() e f.getSalario(), que são específicos 
da classe Funcionario. 


12.5 Polimorfismo 


A palavra polimorfismo quer dizer múltiplas formas. Na programação orientada a objetos, polimorfismo se 
apresenta de diferentes maneiras. Nesta seção, abordaremos o polimorfismo por herança. 

Polimorfismo por herança permite que uma classe, em um nível mais genérico (a classe mãe), indique a 
necessidade de executar determinada operação. Porém, nesse nível mais genérico, essa classe mãe não tem 
conhecimento (ou dados) suficientes para realizar essa ação. Ficará, portanto, sob responsabilidade das 
classes filhas implementar a realização de tal ação. 

Como a classe genérica não implementa todas as ações de que necessita, ela é chamada classe abstrata, 
não podendo ser instanciada, mas servindo de molde para as filhas que venham a ser criadas. Já as classes 
filhas, por sua vez, são chamadas concretas, porque implementam o que é solicitado pela classe mãe. 

No diagrama a seguir, pode ser visto que a classe Funcionario é considerada abstrata. Essa classe con- 
sidera que, para todo funcionário, é necessário calcular o salário. Porém, a forma de realizar esse cálculo 
depende do tipo de funcionário. Sendo assim, a classe Funcionario apenas indica que essa ação é necessá- 
ria, deixando que suas subclasses resolvam o problema. 

As classes Vendedor e FreeLancer são subclasses de Funcionario e possuem conhecimento suficiente 
para realizar a ação de calcular o salário final. Para vendedor, esse cálculo é realizado somando o valor 
do salário-base com o valor da comissão. Para o FreeLancer, esse cálculo é realizado multiplicando-se a 
quantidade de dias trabalhados pelo valor do dia. 

Observe, portanto, que a forma do cálculo muda de acordo com a especialização do funcionário. Isso 
quer dizer que a ação de calcular o salário final é polimórfica. 

A hierarquia de classes apresentada no diagrama a seguir, será implementada em C++ e JAVA nas pró- 
ximas seções. 
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<<abstrata>> Funcionario 


Nome 


setNome(n) 
setNome():n 
<<abstrato>> calcularSalarioFinal():s 


Vendedor FreeLancer 
SalarioBase DiasTrabalhados 
Comissao ValorDia 
setSalarioBase(s) setDiasTrabalhados(d) 
setComissao(c) setValorDia(v) 
getSalarioBase:s getDiasTrabalhados():d 
getComissao(s) getValorDia():v 
calcularSalarioFinal():s calcularSalarioFinal():s 


12.5.1 Polimorfismo em C++ 


O polimorfismo de herança está sendo, aqui, exemplificado por meio do uso das classes Funcionario 
(arquivos Funcionario.hpp € Funcionario.cpp), Vendedor (arquivos Vendedor. hpp € Vendedor.cpp) e 
FreeLancer (arquivos FreeLancer.hpp € FreeLancer.cpp). Essas classes estão contidas em arquivos separa- 
dos, conforme mostrado a seguir. 

Vamos olhar atentamente a implementação (a numeração à esquerda das linhas está sendo utilizada 
apenas para facilitar a explicação). 

O arquivo Funcionario.cpp contém a implementação de Funcionario.hpp. Como já foi comentado, 
a classe Funcionario representa um nível mais genérico, que atende qualquer tipo de Funcionario. Assim 
sendo, ela possui como atributo apenas nome, junto com os métodos getNome e setNome. 

O detalhe mais importante da classe Funcionario. hpp está descrito na linha 12, onde está o cabeçalho 
do método calcularSalarioFinal(). Esse método está marcado como virtual. Assim, em Funcionario. 
cpp não haverá implementação dele. Esse método está indicado na classe runcionario.hpp para deixar 
claro que cada classe filha de Funcionario terá uma implementação desse método de acordo com suas 
necessidades, contudo, a implementação é obrigatória. 


Arquivo Funcionario.hpp 


1. fifndef Funcionario H 
2. #define Funcionario H 


3. finclude <string> 
4. using namespace std; 


5. class Funcionario { 


6. private: 

Th string nome; 

8. public: 

So Funcionario(); 

10. string getNome() ; 

Lo void setNome (string n); 

Ag virtual float calcularSalarioFinal(); 
Lo Jr 


14. #endif 
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Arquivo Funcionario.cpp 


ISE 
16. 


76 


18. 


TOR 


20. 


21. 


22. 


23. 


24. 


257 


26. 


#include “Funcionario.hpp” 
#include <iostream> 


using namespace std; 


Funcionario::Funcionario() { 


string Funcionario: :getNome() { 
return nome; 


void Funcionario: :setNome(string n) { 
nome = n; 


float Funcionario::calcularSalarioFinal() { }; 


O arquivo Vendedor .cpp contém a implementação de vendedor .hpp. Conforme descrito na linha 32, 
Vendedor é uma extensão da classe Funcionario, ou seja, Vendedor é classe filha e Funcionario é classe mãe. 
Sendo assim, a classe vendedor possui todas as suas especificidades mais a herança recebida de Funciona- 
rio. Nessa herança, está incluída a obrigatoriedade de implementar o método calcularsalarioFinal(). Na 
linha 42, vê-se a declaração desse método no arquivo vendedor .hpp. Da linha 61 à 63, vê-se a implementação 
desse método fornecida pela classe vendedor. cpp. 


Com essa implementação feita, a classe vendedor passa a ser considerada uma classe concreta e, por- 
tanto, poderá ser instanciada quando necessário. 


Arquivo Vendedor.hpp 

27. fifndef Vendedor H 

28. fdefine Vendedor H 

29. finclude “Funcionario.hpp” 

30. finclude <string> 

31. using namespace std; 

32. class Vendedor: public Funcionario ( 
So private: 

34. float salarioBase; 

So float comissao; 

36. public: 

Sho Vendedor (); 

38. float getSalarioBase(); 

39. void setSalarioBase(float s); 
40. float getComissao(); 

41. void setComissao(float c); 
42. float calcularSalarioFinal(); 
43. }; 

44. #endif 
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Arquivo Vendedor.cpp 


45. finclude “Vendedor. hpp” 
46. finclude <iostream> 
47. Vendedor: :Vendedor() { 


48. } 


49. float Vendedor: :getSalarioBase() { 
50. return salarioBase; 
bo 


52. void Vendedor: :setSalarioBase(float s) { 
59% salarioBase = s; 
54. } 


55. float Vendedor: :getComissao() { 
56. return comissao; 
Dita 


58. void Vendedor: : setComissao(float c) { 
59. comissao = C; 
60. } 


61. float Vendedor: :calcularSalarioFinal() { 
62. return salarioBase + comissao; 
63. } 


O arquivo FreeLancer.cpp contém a implementação de Freelancer. hpp. Conforme descrito na linha 
69, FreeLancer é uma extensão da classe Funcionario, ou seja, FreeLancer é classe filha e Funcionario 
é classe mãe. 

Sendo assim, a classe FreeLancer possui todas as suas especificidades mais a herança recebida de Fun- 
cionario. Nessa herança, está incluída a obrigatoriedade de implementar o método calcularsalarioFi- 
nal (). Na linha 79, vê-se a declaração desse método no arquivo vendedor .hpp. Da linha 98 à 100, vê-se a 
implementação desse método fornecida pela classe FreeLancer .cpp. 

Com essa implementação feita, a classe FreeLancer passa a ser considerada uma classe concreta e, 
portanto, poderá ser instanciada quando necessário. 


Arquivo Freelancer.hpp 


64. fifndef FreeLancer H 
65. fdefine FreeLancer H 


66. finclude “Funcionario.hpp” 
67. finclude <string> 


68. using namespace std; 


69. class FreeLancer: public Funcionario ( 


70. private: 

Tb int diasTrabalhados; 
T2 float valorDia; 

T3 public: 

74. FreeLancer(); 


He int getDiasTrabalhados (); 
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76. void setDiasTrabalhados (int d); 
77. float getValorDia(); 

78. void setValorDia(float v); 

79. float calcularSalarioFinal(); 
80. 3); 

81. #endif 


Arquivo Freelancer.cpp 


82. finclude “FreeLancer.hpp” 
83. finclude <iostream> 


84. FreeLancer::FreeLancer() { 
85. 3 


86. int FreeLancer::getDiasTrabalhados() { 
87. return diasTrabalhados; 
88. } 


89. void FreeLancer: :setDiasTrabalhados(int d) { 
90. diasTrabalhados = d; 
91. ) 


92. float FreeLancer::getValorDia() { 
93. return valorDia; 
94. } 


95. void FreeLancer::setValorDia(float v) { 
96. valorDia = v; 
97.) 


98. float FreeLancer::calcularSalarioFinal() { 
99. return diasTrabalhados * valorDia; 
100. 3 


Por fim, nessa apresentação de um exemplo de polimorfismo, temos a classe Empresa, descrita da linha 
101a 122, no arquivo Empresa.cpp. 

A classe Empresa foi criada com a intenção de usar as classes concretas descritas acima e apresentar 
a manifestação do comportamento polimórfico do método calcularSalarioFinal(). 

Observe, nas linhas 112 e 113, a criação, respectivamente, da variável v, referência para um objeto do 
tipo Vendedor, e da variável £, referência para um objeto do tipo FreeLancer (não há nenhuma instanciação 
explícita da classe Funcionario porque se trata de uma classe abstrata). 

Da linha 114 à 116, os atributos do objeto v são inicializados. Da linha 118 à 120, os atributos do 
objeto £ são inicializados. 

As linhas 117 e 121 invocam o método obtersSalarioDoFuncionario(). Na linha 117, esse método rece- 
be como parâmetro o endereço de uma variável do tipo vendedor. Já na linha 121, esse mesmo método recebe 
como parâmetro o endereço de uma variável do tipo FreeLancer. 

primeira vista, poderíamos pensar que isso poderia gerar algum tipo de erro (em tempo de compilação 
ou em tempo de execução). Contudo, se executarmos esse exemplo, não incorreremos em nenhum tipo de erro. 

O motivo de tudo funcionar corretamente está na linha 107, onde vemos o cabeçalho do método ob- 
terSalarioDoFuncionario(). Observe que, nessa linha, o parâmetro esperado pelo método é um ponteiro 
para o tipo Funcionario. Assim, na invocação desse método, podemos usar qualquer tipo de variável que 
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esteja dentro do conjunto de classes filhas de Funcionario, já que uma classe filha pode ser considerada 
um tipo especial da classe mãe (Vendedor é um Funcionario e FreeLancer também é um Funcionario). 

E, assim sendo, quando a linha 108 for executada, a aplicação não precisa se preocupar com qual das 
versões do método calcularSalarioFinal() será executada, se aquela escrita na classe Vendedor ou a 
escrita na classe FreeLancer. Essa decisão será tomada pelo tipo de referência passada. Como a primeira 
invocação, ocorrida na linha 117, mandou uma referência para um Vendedor, a versão executada foi aquela 
escrita no arquivo Vendedor . java. Já na segunda invocação, ocorrida na linha 121, foi mandada uma refe- 
rência para um FreeLancer, a versão executada foi aquela escrita no arquivo FreeLancer. java. 

É importante observar que, com essa estratégia, não há necessidade de uso de estruturas condicionais 
para descobrir qual o tipo de funcionário em questão para poder invocar a versão correta do método. Isso 
facilita muito a manutenção do código. 

Eis aí o polimorfismo de herança: o método é o mesmo, calcularSalarioFinal(), porém, dependen- 
do do objeto que o acione, a implementação assume diferentes formas. 


Arquivo Empresa.cpp 


101. finclude “Funcionario.hpp” 
102. finclude “Vendedor. hpp” 
103. finclude “FreeLancer.hpp” 
104. finclude <string> 

105. finclude <iostream> 


106. using namespace std; 


107. float obterSalarioDoFuncionario(Funcionario *funcionario) { 


108. float resposta = funcionario->calcularSalarioFinal(); 
109. return resposta; 
110. 3 


111. int main() { 


112. Vendedor v; 

LS FreeLancer f; 

114. v.setNome(“Carlos"); 

115. v.setSalarioBase(2000); 

116. v.setComissao(3000); 

INES cout << “Salario do vendedor: “ << obterSalarioDoFuncionario(&v); 
118. f.setNome(“Clara”"); 

119. f.setDiasTrabalhados (20); 

120. f.setValorDia( 150); 

121. cout << “Salario do free lancer: “ << obterSalarioDoFuncionario(&f); 
T22} 


12.5.2 Polimorfismo em JAVA 


O polimorfismo de herança está sendo, aqui, exemplificado por meio do uso das classes Funcionario, 
Vendedor e€ FreeLancer. Essas classes estão contidas em arquivos separados, conforme a seguir. 

Vamos olhar atentamente cada arquivo (a numeração à esquerda das linhas está sendo utilizada apenas 
para facilitar a explicação). 

A classe Funcionario, está implementada no arquivo Funcionario. java, da linha 1 à 12. Como já 
foi comentado, a classe Funcionario representa um nível mais genérico, que atende qualquer tipo de Fun- 
cionario. Assim sendo, ela possui como atributo apenas nome, em conjunto com os métodos getNome e 
setNome. 

O detalhe mais importante da classe Funcionario está descrito na linha11, onde está o cabeçalho do 
método calcularSalarioFinal(). Esse método não possui corpo, ou seja, após o cabeçalho já se encontra 
um ponto e vírgula, razão pela qual ele carrega o modificador abstract consigo. Esse método está indicado 
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na classe Funcionario para deixar claro que cada classe filha de Funcionario terá uma implementação 
desse método, de acordo com suas necessidades, contudo, a implementação é obrigatória. 


Arquivo Funcionario.java 


1. public abstract class Funcionario ( 


Pio private String nome; 
Bo public Funcionario() { 
4 } 
o public String getNome() ( 
return nome; 
7 } 
8. public void setNome(String nome) { 
9. this.nome = nome; 
10. } 
Kilo public abstract float calcularSalarioFinal(); 
12. 5 


A classe vendedor está implementada no arquivo vendedor. java. Conforme descrito na linha 13, ven- 
dedor é uma extensão da classe Funcionario, ou seja, Vendedor é classe filha e Funcionario é classe mãe. 

Sendo assim, a classe vendedor possui todas as suas especificidades mais a herança recebida de Funcio- 
nario. Nessa herança, está incluída a obrigatoriedade de implementar o método calcularsSalarioFinal(), 
que pode ser visto da linha 31 à 34. 

Na linha 31, é possível ver a marcação eoverride, deixando claro que o método a seguir está sobre- 
pondo algo que foi herdado. 

Na linha 32 pode-se ver o cabeçalho do método calcularSalarioFrinal(). Observe que é exatamente 
igual ao declarado na linha 11 da classe Funcionario. java. Com essa implementação feita, a classe Ven- 
dedor passa a ser considerada uma classe concreta e, portanto, poderá ser instanciada quando necessário. 


Arquivo Vendedor.java 


13. public class Vendedor extends Funcionario ( 


14. private float salarioBase; 

15, private float comissao; 

16. public Vendedor() { 

17A super(); 

18. } 

19. public float getSalarioBase() { 
20. return salarioBase; 

DAL es } 

22. public void setSalarioBase( float salarioBase) { 
23. this.salarioBase = salarioBase; 
24. } 

255 public float getComissao() { 

26. return comissao; 


DT o } 
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28. public void setComissao( float comissao) { 
29. this.comissao = comissao; 

30. } 

Silo Goverride 

328 public float calcularSalarioFinal() { 

33. return salarioBase + comissao; 

34. } 

Bjs y 


A classe FreeLancer está implementada no arquivo FreeLancer. java. Conforme descrito na linha 36, 
FreeLancer é uma extensão da classe Funcionario, ou seja, FreeLancer é classe filha e Funcionario é 
classe mãe. 

Sendo assim, a classe FreeLancer possui todas as suas especificidades mais a herança recebida de Fun- 
cionario. Nessa herança, está incluída a obrigatoriedade de implementar o método calcularsalarioFi- 
nal(), que pode ser visto da linha 53 à 56. 

Na linha 53, é possível ver a marcação eoverride, deixando claro que o método a seguir está sobre- 
pondo algo que foi herdado. 

Na linha 54, pode-se ver o cabeçalho do método calcularSalarioFinal(). Observe que é exatamente 
igual ao declarado na linha 11 da classe Funcionario. java. Com essa implementação feita, a classe Free- 
Lancer passa a ser considerada uma classe concreta e, portanto, poderá ser instanciada quando necessário. 


Arquivo FreeLancer 


36. public class FreeLancer extends Funcionario ( 


So private int diasTrabalhados; 

38. private float valorDia; 

9 public FreeLancer() { 

40. } 

41. public int getDiasTrabalhados() { 

42. return diasTrabalhados; 

43. } 

44. public void setDiasTrabalhados (int diasTrabalhados) { 
45. this.diasTrabalhados = diasTrabalhados; 
46. } 

47. public float getValorDia() { 

48. return valorDia; 

49. } 

50. public void setValorDia(float valorDia) { 
SIE this.valorDia = valorDia; 

52. } 

So foverride 

54. public float calcularSalarioFinal() { 

557 return diasTrabalhados * valorDia; 

56. } 


Sla $ 


Capítulo 12 Introdução à programação orientada a objetos | 503 


Por fim, nessa apresentação de um exemplo de polimorfismo, temos a classe Empresa, descrita da linha 
58 à 76, no arquivo Empresa. java. 

A classe Empresa foi criada com a intenção de usar as classes concretas descritas acima e apresentar 
a manifestação do comportamento polimórfico do método calcularSalarioFinal(). 

Observe, nas linhas 61 e 62, a criação, respectivamente, da variável v, referência para um objeto 
do tipo vendedor, e da variável £, referência para um objeto do tipo FreeLancer (não há nenhuma 
instanciação explícita da classe Funcionario, porque se trata de uma classe abstrata). 

Da linha 63 à 65, os atributos do objeto v são inicializados. Da linha 67 à 69, os atributos do objeto £ 
são inicializados. 

As linhas 66 e 70 invocam o método obterSalarioDoFuncionario(). Na linha 66, esse método recebe 
como parâmetro uma variável do tipo vendedor. Já na linha 70, esse mesmo método recebe como parâme- 
tro uma variável do tipo FreeLancer. À primeira vista, poderíamos pensar que isso poderia gerar algum 
tipo de erro (em tempo de compilação ou em tempo de execução). Contudo, se executarmos esse exemplo, 
não incorreremos em nenhum tipo de erro. 

O motivo de tudo funcionar corretamente está na linha 72, onde vemos o cabeçalho do método ob- 
terSalarioDoFuncionario(). Observe que, nessa linha, o parâmetro esperado pelo método é do tipo Fun- 
cionario. Assim, na invocação desse método, podemos usar qualquer tipo de variável que esteja dentro do 
conjunto de classes filhas de Funcionario, já que uma classe filha pode ser considerada um tipo especial da 
classe mãe (Vendedor é um Funcionario € FreeLancer também é um Funcionario). 

E, assim sendo, quando a linha 73 for executada, a aplicação não precisa se preocupar com qual das 
versões do método calcularSalarioFinal() será executada, se aquela escrita na classe vendedor ou a 
escrita na classe FreeLancer. Essa decisão será tomada pelo tipo de referência passada. Como a primeira 
invocação, ocorrida na linha 66, mandou uma referência para um vendedor, a versão executada foi aquela 
escrita no arquivo Vendedor. java. Já na segunda invocação, ocorrida na linha 70, foi mandada uma refe- 
rência para um FreeLancer, a versão executada foi aquela escrita no arquivo FreeLancer. java. 

É importante observar que, com essa estratégia, não há necessidade de uso de estruturas condicionais 
para descobrir qual o tipo de funcionário em questão para poder invocar a versão correta do método. Isso 
facilita muito a manutenção do código. 

Eis aí o polimorfismo de herança: o método é o mesmo, calcularsalarioFinal(), porém, dependen- 
do do objeto que o acione, a implementação assume diferentes formas. 


Arquivo Empresa.java 


58. import java.util.Scanner; 
59. public class Empresa { 


60. public static void main(String args[]) { 

61. Vendedor v = new Vendedor(); 

62. FreeLancer f = new FreeLancer(); 

63. v.setNome(“Carlos"); 

64. v.setSalarioBase(2000); 

65. v.setComissao(3000); 

66. System.out.println(“Salario vendedor: “ + obterSalarioDoFuncionario(v)); 
67. f.setNome(“Clara”); 

68. f.setDiasTrabalhados (20); 

69. f.setValorDia( 150); 

70. System.out.println(“Salario free lancer: “ + obterSalarioDo Funcionario(f)); 
71. } 

72. public static float obterSalarioDoFuncionario(Funcionariofuncionario) ( 
73. float resposta = funcionario.calcularSalarioFinal(); 

74. return resposta; 

Bo 3 


76.) 
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EXERCÍCIOS RESOLVIDOS 


BR Defina uma classe chamada TIPO com os seguintes atributos: código do tipo e percentual do tipo. Os 
percentuais devem seguir a tabela abaixo. 


Tipo % de imposto 
1. Alimentação 10 
2. Limpeza 20 


Defina uma classe chamada PRODUTO com os seguintes atributos: descrição, tipo (que deve existir 
na classe TIPO), preço e imposto e o método calcular o preço final, ou seja, preço mais imposto. Faça um 
programa que carregue os dados de um produto e mostre seu preço final. 


Resolução em C++: 


Arquivo Tipo.hpp 


Hifndef Tipo H 
fdefine Tipo H 
using namespace std; 
class Tipo 
{ 
public: 
Tipo(); 
void setCodigo(int c); 
int getCodigo(); 
void setPercentual (float p); 
float getPercentual(); 
private: 
int codigo; 
float percentual; 
k; 
#endif 


Arquivo Tipo. cpp 


#include “Tipo.hpp” 
using namespace std; 


Tipo::Tipo() 


{ 
} 
void Tipo::setCodigo(int c) 
{ 
codigo = c; 
int Tipo: :getCodigo() 
{ 
return codigo; 
} 


void Tipo::setPercentual(float p) 
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{ 
percentual = p; 
} 
float Tipo: :getPercentual() 
{ 
return percentual; 
} 


Arquivo Produto .cpp 


#ifndef Produto H 
fdefine Produto H 


include “Tipo.hpp” 
include <string> 


using namespace std; 


class Produto 
{ 
public: 
Produto(); 
void setDescricao(string n); 
string getDescricao(); 
void setTipo(Tipo t); 
Tipo getTipo(); 
void setPreco(float preco); 
float getPreco(); 
float calculaPrecoFinal(); 
float getImposto(); 
private: 
string descricao; 
Tipo tipo; 
float preco; 
float imposto; 
void setImposto(float i); 


+; 


Fendi f 
Arquivo Produto.cpp 


include <string> 
include “Tipo.hpp” 
include “Produto.hpp” 
using namespace std; 


Produto: :Produto() 
{ 
} 


void Produto: :setDescricao(string n) 


{ 


descricao = n; 
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+ 
string Produto: :getDescricao() 
{ 
return descricao; 

i 
void Produto: :setTipo(Tipo t) 
{ 

tipo = t; 

setImposto(preco * tipo.getPercentual() / 100); 
} 


Tipo Produto: :getTipo() 


{ 
return tipo; 
} 
void Produto: :setPreco(float p) 
{ 
preco = p; 
} 
float Produto: :getPreco() 
{ 
return preco; 
} 
void Produto: :setImposto(float i) 
{ 
imposto = i; 
dy 
float Produto: :getImposto() 
{ 
return imposto; 
} 
float Produto::calculaPrecoFinal() 
i 
return preco + imposto; 
} 


Arquivo ex1.cpp 


#include <cstdlib> 
#include <string> 
#include <stdio.h> 
#include <iostream> 
#include “Produto .hpp” 


using namespace std; 
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int main(int argc, char *argv[]) 
{ 
/* Início da criação e dos objetos que representarão os tipos possíveis de produto. 
Se, com o passar do tempo, outros tipos forem criados, basta acrescentá-los ao 
vetor tipos, não sendo necessária qualquer alteração na classe Produto. */ 


Tipo tipos[2]; 
tipos[0].setCodigo(1); 
tipos[0].setPercentual(10); 
tipos[1].setCodigo(2); 
tipos[1].setPercentual(20); 


/* Inicio do cadastramento do objeto Produto. */ 
string descAux; 
float precoAux; 
int tipoAux; 
Produto p; 
printf(“AnDigite a descrição do produto: “); 
cin >> descAux; 
p.setDescricao(descAux) ; 
printf(“AnDigite o preço do produto: “); 
scanf (“3f%*c”, &precoAux) ; 
p.setPreco(precoAux) ; 
printf(“AnDigite o tipo do produto: “); 
scanf (“2Sd%*c”, &tipoAux); 
while (tipoAux != 1 && tipoAux != 2) 

{ 

printf(“\nTipo inválido. Digite novamente “); 
scanf (“%d%*c" ,&tipoAux); 

} 
p.setTipo(tipos[tipoAux-1]); 
printf(“inPreço final = %5.2f”,p.calculaPrecoFinal()); 
getchar(); 
return 0; 


Resolução em JAVA: 


Arquivo Tipo. java 


public class Tipo 


{ 
private int codigo; 
private double percentual; 


public Tipo() 
{ 
} 


public void setCodigo(int c) 


{ 


codigo = c; 
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public int getCodigo() 


{ 
return codigo; 
} 
public void setPercentual(double p) 
5 
percentual = p; 
} 
public double getPercentual() 
f 
return percentual; 
} 


Arquivo Produto.java 


public class Produto 

{ 
private String descricao; 
private Tipo tipo; 
private double preco; 
private double imposto; 


public Produto() 


{ 
+ 
public void setDescricao(String n) 
{ 

descricao = n; 
} 
public String getDescricao() 
{ 

return descricao; 
} 
public void setTipo(Tipo t) 
{ 

tipo = t; 

setImposto(preco * tipo.getPercentual() / 100); 
} 
private void setImposto(double i) 
{ 

imposto = i; 

} 
public Tipo getTipo() 
{ 


return tipo; 
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public void setPreco (double p) 


{ 

preco = p; 
} 
public double getPreco() 
{ 

return preco; 
i 
public double getImposto() 
{ 

return imposto; 
} 
public double calculaPrecoFinal() 
{ 

return preco + imposto; 

} 


} 
Arquivo ex1.java 


import java.util.*; 
public class ex1 


{ 
public static void main(String[] args) 
{ 
Scanner entrada = new Scanner (System.in); 
Tipo tipos[] = new Tipo[2]; 
tipos[0] = new Tipo(); 


tipos[0].setCodigo(1); 
tipos[0].setPercentual(10); 
tipos[1] = new Tipo(); 
tipos[1].setCodigo(2); 
tipos[1].setPercentual(20); 


String descAux; 
double precoAux; 
int tipoAux; 
Produto p = new Produto(); 
System.out.println(“inDigite a descrição do produto: “); 
descAux = entrada.next(); 
p.setDescricao(descAux) ; 
System.out.println(“inDigite o preço do produto: “); 
precoAux = entrada.nextDouble(); 
p.setPreco(precoAux) ; 
System.out.println(“inDigite o tipo do produto: “); 
tipoAux = entrada.nextInt(); 
while (tipoAux != 1 && tipoAux != 2) 
{ 
System.out.println(“\nTipo inválido. Digite novamente “); 
tipoAux = entrada.nextInt(); 
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p.setTipo(tipos[tipoAux-1]); 
System.out .println(“nPreço final="+p.calculaPrecoFinal()); 


IFA Refazer o exercício anterior para cadastrar cinco produtos. Para cada produto, mostrar o preço final e, 
posteriormente, calcular e mostrar a média dos preços finais dos produtos e a quantidade de produtos 
com preço final superior a 40. 


Resolução em C++: 


Todos os arquivos do exercício anterior devem ser mantidos, exceto o arquivo ex1.cpp, que deve ser 
alterado para o arquivo abaixo. 


Arquivo ex2.cpp 


include <cstdlib> 
include <string> 
include <stdio.h> 
include <iostream> 
include “Produto.hpp” 


using namespace std; 


int main(int argc, char *argv[]) 
s 
/* Início da criação e dos objetos que representarão os tipos possíveis de pro- 
duto. 
Se, com o passar do tempo, outros tipos forem criados, basta acrescentá-los 
ao vetor tipos, não sendo necessária qualquer alteração na classe Produto. */ 


Tipo tipos[2]; 
tipos[0].setCodigo(1); 
tipos[0].setPercentual(10); 


tipos[1].setCodigo(2); 
tipos[1].setPercentual(20); 


/* Início do cadastramento do objeto Produto. */ 
string descAux; 

float precoAux, soma = 0, media; 

int tipoAux, qtde = 0, i; 

Produto p[5]; 


for (i=0ji<=4,i++) 

{ 

printf(“\nDigite a descrição do produto: “); 
cin >> descAux; 

p[i].setDescricao(descAux) ; 

printf(“AnDigite o preço do produto: “); 
scanf (“3Sf%*c”, &precoAux) ; 
p[i].setPreco(precoAux) ; 

printf(“inDigite o tipo do produto: “); 
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scanf (“3Sd%*c”, &tipoAux); 
while (tipoAux != 1 && tipoAux != 2) 
{ 
printf(“\nTipo inválido. Digite novamente “); 
scanf (“%d%*c" ,&tipoAux); 
} 
p[i].setTipo(tipos[tipoAux-1]); 
printf(“inPreço final = %5.2f”,p[i].calculaPrecoFinal()); 
soma = soma + p[i].calculaPrecoFinal(); 
if (p[i].calculaPrecoFinal() > 40) 
qtde++; 
} 
media = soma/5; 
printf (“\nMédia dos preços finais = %5.2f”,media); 
printf(“\nQuant. de produtos com preço final > a 40 = %d”,qtde); 


getchar(); 
return 0; 
} 
Resolução em JAVA: 


Todos os arquivos do exercício anterior devem ser mantidos, exceto o arquivo ex1.java, que deve ser 
alterado para o arquivo a seguir. 


Arquivo ex2.java 


import java.util.*; 
public class ex2 
{ 
public static void main(String[] args) 
{ 
Scanner entrada = new Scanner (System.in); 
Tipo tipos[] = new Tipo[2]; 
tipos[0] = new Tipo(); 
tipos[0].setCodigo(1); 
tipos[0].setPercentual(10); 
tipos[1] = new Tipo(); 
tipos[1].setCodigo(2); 
tipos[1].setPercentual(20); 


String descAux; 
double precoAux, m, soma = 0; 
int tipoAux, i, qtde = 0; 


Produto p[] = new Produto[5]; 
for (i=0;i<5, i++) 

$ 

p[i] = new Produto(); 


System.out.println(“”\nDigite a descrição do produto: “); 
descAux = entrada.next(); 

p[i].setDescricao(descAux); 
System.out.println(“\nDigite o preço do produto: “); 
precoAux = entrada.nextDouble(); 
p[i].setPreco(precoAux); 
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EA Defina uma classe denominada CARGO com os seguintes atributos: número do cargo e valor da hora 
trabalhada. Defina uma classe FUNCIONÁRIO com os seguintes atributos: código do cargo, sexo e 
quantidade de horas trabalhadas. Essa classe deve possuir, ainda, um método para calcular o salário 
final, ou seja, o salário de acordo com o cargo (valor da hora trabalhada multiplicado pelo número de 
horas trabalhadas) mais o adicional, ou seja, para o sexo feminino (F ou f), adicional de 20% sobre o 
salário calculado; e para o sexo (M ou m), não tem direito ao adicional. Faça um programa que carre- 


System.out.println(“inDigite o tipo do produto: “); 
tipoAux = entrada.nextInt(); 
while (tipoAux != 1 && tipoAux != 2) 

{ 

System.out.println(“\nTipo inválido. Digite novamente “); 
tipoAux = entrada.nextInt(); 

y 
p[i].setTipo(tipos[tipoAux-1]); 
System.out.println(“inPreço final = “+p[i].calculaPrecoFinal()); 
soma = soma + +p[i].calculaPrecoFinal(); 

if (p[i].calculaPrecoFinal() > 40) 


qtde++; 
} 
m = soma/5; 
System.out.println(“Média = “+m); 
System.out.println(“Quantidade = “+qgtde); 


gue os dados de três cargos e um funcionário, calcule e mostre seu salário final. 


Resolução em C++: 


Arquivo Cargo. java 


fifndef Cargo H 
fdefine Cargo H 


using namespace std; 


class Cargo 


{ 
public: 


Cargo(); 


void setNumero(int n); 


int getNumero(); 
void setValorHora(float vh); 
float getValorHora(); 


private: 
int 


numero; 


float valorhora; 


}; 


#endif 
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Arquivo Cargo.cpp 


#include “Cargo.hpp” 
using namespace std; 


Cargo::Cargo() 


{ 
} 
void Cargo: :setNumero(int n) 
{ 
numero = n; 
} 
int Cargo: :getNumero() 
{ 
return numero; 
+ 
void Cargo: :setValorHora(float vh) 
i 
valorhora = vh; 
} 
float Cargo::getValorHora() 
{ 
return valorhora; 
} 


Arquivo Funcionario.hpp 


#ifndef _Funcionario H 
#define Funcionario H 


#include “Cargo.hpp” 
#include <string> 


using namespace std; 


class Funcionario 
{ 
public: 

Funcionario(); 
void setCargoFuncionario(Cargo c); 
Cargo getCargoFuncionario(); 
void setSexo(char s); 
char getSexo(); 
void setAdicional(float a); 
float getAdicional(); 
void setQuantidadeHoras (float qh); 
float getQuantidadeHoras(); 
float getSalarioBruto(); 
float calculaSalarioFinal(); 
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private: 
Cargo cargofuncionario; 
char sexo; 
float adicional; 
float quantidadehoras; 
float salariobruto; 
void setSalarioBruto(float sb); 


#endif 


Arquivo Funcionario. java 
#include “Cargo.hpp” 
#include “Funcionario.hpp” 
#include <string> 


using namespace std; 


Funcionario: :Funcionario() 


{ 
7 
void Funcionario::setCargoFuncionario(Cargo c) 
{ 

cargofuncionario = c; 

setSalarioBruto(quantidadehoras * cargofuncionario.getValorHora()); 
+ 
Cargo Funcionario::getCargoFuncionario() 
{ 

return cargofuncionario; 
} 
void Funcionario: :setSexo(char s) 
1 
sexo = sS; 

} 
char Funcionario: :getSexo() 
{ 

return sexo; 
} 
void Funcionario::setQuantidadeHoras (float qh) 
{ 

quantidadehoras = qh; 

+ 
float Funcionario::getQuantidadeHoras() 
{ 

return quantidadehoras; 
+ 


void Funcionario::setSalarioBruto(float sb) 


{ 


salariobruto = sb; 
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float Funcionario::getSalarioBruto() 


{ 

return salariobruto; 
} 
void Funcionario::setAdicional(float a) 
{ 

adicional = a; 

} 
float Funcionario: :getAdicional() 
{ 

return adicional; 
} 
float Funcionario::calculaSalarioFinal() 
{ 

return salariobruto + salariobruto * adicional/100; 
} 


Arquivo ex3.cpp 


#include <cstdlib> 
#include <string> 
#include <stdio.h> 
#include <iostream> 
#include “Funcionario.hpp” 


using namespace std; 


int main(int argc, char *argv[]) 
{ 

Cargo cargos[3]; 
cargos[0].setNumero(1); 
cargos[0].setValorHora(15); 
cargos[1].setNumero(2); 
cargos[1].setValorHora(20); 
cargos[2].setNumero(3); 
cargos[2].setValorHora(32); 


Funcionario f; 

int cargof; 

float q; 

char s; 

printf(“\nDigite a quantidade de horas trabalhadas: “); 
scanf (“3f%*c”,&d); 

f.setQuantidadeHoras(q); 

printf(“\nDigite o cargo do funcionário: “); 
scanf (“$d%*c”,&cargof); 
f.setCargoFuncionario(cargos[cargof-1]); 
printf(“\nDigite o sexo: “); 
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scanf (“$c%*c”,&s); 
f.setSexo(s); 
if (f.getSexo() == 'M') 
f.setAdicional(0); 
else 
f.setAdicional(20); 
printf(“inSalário Final = %5.2f”,f.calculaSalarioFinal()); 


getchar(); 
return 0; 
} 
Resolução em JAVA: 


Arquivo Funcionario.java 


public class Cargo 


{ 
private int numero; 
private double valorhora; 
public Cargo() 
{ 
} 
public void setNumero(int n) 
{ 
numero = n; 
} 
public int getNumero() 
{ 
return numero; 
} 
public void setValorHora(double vh) 
{ 
valorhora = vh; 
} 
public double getValorHora() 
{ 
return valorhora; 
} 
} 


Arquivo Funcionario.java 


public class Funcionario 

{ 
private Cargo cargofuncionario; 
private char sexo; 
private double adicional; 
private double quantidadehoras; 
private double salariobruto; 


public Funcionario() 


{ 


Capítulo 12 Introdução à programação orientada a objetos | 517 


} 
public void setCargoFuncionario(Cargo c) 
{ 
cargofuncionario = c; 
setSalarioBruto(quantidadehoras * cargofuncionario.getValorHora()); 
} 
private void setSalarioBruto(double sb) 
{ 
salariobruto = sb; 
} 
public Cargo getCargoFuncionario() 
{ 
return cargofuncionario; 
} 
public void setSexo(char s) 
{ 
sexo = s; 
h 
public char getSexo() 
{ 
return sexo; 
} 
public void setAdicional(double a) 
{ 
adicional = a; 
} 
public double getAdicional() 
{ 
return adicional; 
} 
public void setQuantidadeHoras (double qh) 
{ 
quantidadehoras = qh; 
} 
public double getQuantidadeHoras() 
{ 
return quantidadehoras; 
} 


public double getSalarioBruto() 


return salariobruto; 
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public double calculaSalarioFinal() 


{ 


return salariobruto + salariobruto * adicional/100; 


Arquivo ex3.java 


import java.util.*; 
public class ex3 
{ 
public static void main(String[] args) 
{ 
Scanner dado = new Scanner(System.in); 
Cargo cargos[] = new Cargo[3]; 
Funcionario f = new Funcionario(); 


cargos[0] = new Cargo(); 
cargos[0].setNumero(1); 
cargos[0].setValorHora(15); 
cargos[1] = new Cargo(); 
cargos[1].setNumero(2); 
cargos[1].setValorHora(20); 
cargos[2] = new Cargo(); 
cargos[2].setNumero(3); 
cargos[2].setValorHora(32); 


int cargof; 
double q; 
char s; 
System.out.println(“inDigite a quantidade de horas trabalhadas: “); 
q = dado.nextDouble(); 
f.setQuantidadeHoras (q); 
System.out.println(“inDigite o cargo do funcionário: “); 
cargof = dado.nextInt(); 
f.setCargoFuncionario(cargos[cargof-1]); 
System.out.println(“inDigite o sexo: “); 
s = dado.next ().charAt(0); 
f.setSexo(s); 
if (f.getSexo() == 'M') 
f.setAdicional(0); 
else 
f.setAdicional(20); 
System.out.println(“inSalário Final = “+f.calculaSalarioFinal()); 


ES Uma imobiliária comercializa dois tipos de imóveis (1 — terrenos e 2 — casas). Cada tipo de imóvel 
possui características diferentes. 
Todo e qualquer imóvel possui um proprietário, uma quadra, um lote, uma área, um valor de venda, 
situação (1 — à venda; 2 — vendido; 3 — em negociação) e valor da comissão (não pode ultrapassar 10% do 
valor do imóvel). 


Capítulo 12 Introdução à programação orientada a objetos | 519 


Casas possuem informação da área construída. 
Cada tipo de imóvel tem um cálculo de IPTU diferente. 


Imóvel territorial: IPTU = 2% do valor do imóvel. 
Casas: IPTU = 1% do valor do imóvel. 


Implemente classes que representem a realidade acima apresentada. 


Utilize modificadores de acesso nos atributos e métodos de tal forma que se garanta o máximo possível 
de encapsulamento dos objetos. 


Crie uma aplicação para: 
cadastrar, no máximo, 30 imóveis; 
alterar a situação de cada imóvel, lembrando que: 
se a nova situação for a venda ou, em negociação, o valor da comissão será zero. 
se a situação for alterada para vendido, deve ser solicitado o percentual para o cálculo da comissão. 
mostrar o somatório dos valores de todos os imóveis; 


mostrar o somatório dos valores de todas as comissões. 


Resolução em C++: 


Arquivo Imovel.hpp 


/* 
Esta é superclasse de qualquer tipo de imóvel que venha a ser comercializado pela 
imobiliária. 


*/ 


fifndef Imovel H 
fdefine Imovel H 


tinclude <string> 
using namespace std; 


class Imovel { 
private: 
string proprietario; 
string quadra; 
int lote; 
double area; 
double valorIptu; 
string situacao; 
double valorVenda; 
double valorComissaoPaga; 


public: 
Imovel(); 
string getProprietario(); 
void setProprietario(string proprietario); 
string getQuadra(); 
void setQuadra(string quadra); 
int getLote(); 
void setLote(int lote); 
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double getArea(); 

void setArea(double area); 

double getValorIptu(); 

void setValorIptu(double valorIptu); 
string getSituacao(); 

void setSituacao(string situacao); 
double getValorVenda(); 

void setValorVenda( double valorVenda) ; 
double getValorComissaoPaga(); 

void setValorComissaoPaga (double valor); 


ki 


Fendi f 
Arquivo Imovel.cpp 
include “Imovel.hpp” 


#include <iostream> 
#include <string> 


using namespace std; 
Imovel::Imovel() { 


situacao = “a venda”; 
valorComissaoPaga = 0; 


string Imovel::getProprietario() { 
return proprietario; 


void Imovel::setProprietario(string proprietario) 
this->proprietario = proprietario; 


string Imovel::getQuadra() { 
return quadra; 


void Imovel::setQuadra(string quadra) { 
this->quadra = quadra; 


int Imovel::getLote() { 
return lote; 


void Imovel::setLote(int lote) { 
this->lote = lote; 


double Imovel::getArea() { 
return area; 


void Imovel: :setArea (double area) { 
this->area = area; 
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double Imovel::getValorIptu() { 
return valorIptu; 


+ 
void Imovel::setValorIptu(double valorIptu) { 


this->valorIptu = valorIptu; 


} 


string Imovel::getSituacao() { 
return situacao; 


} 


void Imovel::setSituacao(string situacao) { 
this->situacao = situacao; 


double Imovel::getValorVenda() { 
return valorVenda; 


} 


void Imovel::setValorVenda(double valorVenda) { 
this->valorVenda = valorVenda; 


J 


double Imovel::getValorComissaoPaga() { 
return valorComissaoPaga; 


} 


void Imovel::setValorComissaoPaga(double valor) { 
if (valor > 10) 
valor = 10; //limitando a comissão a 10% 
this->valorComissaoPaga = valorVenda * valor / 100; 


Arquivo Casa.hpp 
/* 
Esta é uma das subclasses de Imovel. Na classe Casa ficam os atributos pertinentes 
apenas aos objetos do tipo Casa, além de seu método próprio para cálculo do IPTU. 
*/ 


#ifndef _Casa_H 
#define _Casa_H 


#include “Imovel.hpp” 
#include <string> 


using namespace std; 


class Casa: public Imovel { 
private: 
double areaConstruida; 
public: 
Casa(); 
double getAreaConstruida(); 
void setAreaConstruida(double areaConstruida); 
void calcularIptu(); 


#endif 
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Arquivo Casa.cpp 


finclude “Casa.hpp” 
#include <iostream> 


#include <string> 
using namespace std; 


Casa::Casa() { 


} 


double Casa::getAreaConstruida() { 


return areaConstruida; 


void Casa::setAreaConstruida(double areaConstruida) { 
this->areaConstruida = areaConstruida; 


void Casa::calcularIptu() { 
setValorIptu(getValorVenda() *1 /100); 


Arquivo Terreno .hpp 


/* 

Esta é uma das subclasses de Imovel. Na classe Terreno não há declaração de atribu- 
tos, pois todas as características necessárias aos objetos desse tipo foram herdadas 
da superclasse Imovel. 


Contudo, a classe Terreno contém sua implementação própria do cálculo do IPTU. 
*/ 


#ifndef Terreno H 
#define Terreno H 


#include “Imovel.hpp” 
#include <string> 


using namespace std; 
class Terreno: public Imovel { 


private: 


public: 
Terreno(); 


void calcularIptu(); 


#endif 
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Arquivo Terreno.cpp 


include “Terreno.hpp” 
include <iostream> 
include <string> 


using namespace std; 


Terreno::Terreno() { 


void Terreno::calcularIptu() { 
setValorIptu(getValorVenda() * 2 /100); 


Arquivo Imobibliaria.cpp 


include “Imovel.hpp” 
include “Casa.hpp” 
include “Terreno.hpp” 
include <string> 
include <iostream> 
include <string> 
include <cstdio> 
include <cstring> 


using namespace std; 


/* 
O método menu é responsável por mostrar na tela todas as opções e permitir que o usu- 
ário escolha uma delas. 
*/ 
int menu() { 
int opcao; 
string msg = “1- Cadastrar Imovel in”; 
msg += “2- Alterar situacao de um imóvelin”; 
msg += “3- Somatório do valor dos imóveisn”; 
msg += “4- Somatório do valor das comissõesn”; 
msg += “5- Finalizar execucaoin” ; 
msg += “Digite a opção desejada: “; 
cout << msg; 
cin >> opcao; 
return opcao; 


/* 
O método geraNovoTerreno cria uma nova instância da classe Terreno, atribui valores a 
todos os seus atributos e retorna esse novo objeto. 
*/ 
Terreno geraNovoTerreno() { 
Terreno novoTerreno; 
string propAux, quadAux; 
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int loteAux; 

double areaAux, valorAux; 

cout << “Digite o nome do proprietário: “; 
cin >> propAux; 
novoTerreno.setProprietario(propAux); 
cout << “Digite a quadra: “; 

cin >> quadAux; 

novoTerreno.setQuadra (quadAux) ; 

cout << “Digite o lote: “; 

cin >> loteAux; 

novoTerreno.setLote (loteAux); 

cout << “Digite a área: “; 

cin >> areaAux; 

novoTerreno.setArea (areaAux); 

cout << “Digite o valor de venda: “; 
cin >> valorAux; 
novoTerreno.setValorVenda (valorAux); 
return novoTerreno; 


/* 
O método geraNovaCasa cria uma nova instância da classe Casa, atribui valores a todos 
os seus atributos e retorna esse novo objeto. 


*/ 


Casa geraNovaCasa() { 
Casa novaCasa; 
string propAux, quadAux; 
int loteAux; 
double areaAux, valorAux, areaConstAux; 
cout << “Digite o nome do proprietário: “; 
cin >> propAux; 
novaCasa.setProprietario(propAux) ; 
cout << “Digite a quadra: “; 
cin >> quadAux; 
novaCasa. setQuadra(quadAux) ; 
cout << “Digite o lote: “; 
cin >> loteAux; 
novaCasa.setLote(loteAux) ; 
cout << “Digite a área: ”; 
cin >> areaAux; 
novaCasa.setArea (areaAux) ; 
cout << “Digite o valor de venda: “; 
cin >> valorAux; 
novaCasa.setValorVenda(valorAux); 
cout << “Digite a área construída: “; 
cin >> areaConstAux; 
novaCasa.setAreaConstruida(areaConstAux) ; 
return novaClasa; 


/* 
O método cadastraNovoImovel é responsável por guardar a referência de um novo objeto 
dentro do vetor de imóveis. 
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Importante observar que esse método pode ser utilizado para guardar referência para 
qualquer objeto considerado Imovel, quer seja Terreno, quer seja Casa (polimorfismo). 
*/ 
int cadastraNovoImovel( Imovel imoveis[], int contImovel, Imovel auxiliar) { 

if (contImovel < 30) 1 


imoveis[contImovel] = auxiliar; 
cont Imovel++; 
a 
else { cout << “Vetor de imóveis já está totalmente preenchido. “; 
getchar(); 
} 
return contImovel; 
dy 
/* 


O método gerarValorTotalDosImoveis soma o valor de todos os imóveis cadastrados. 
*/ 
double gerarValorTotalDosImoveis( Imovel imoveis[], int contImovel) ( 
double total = 0; 
for (int i=0; i<contImovel; i++) 
total += imoveis[i].getValorVenda(); 
return total; 


/* 
O método gerarValorTotalComissaoImoveis soma a comissão obtida com todos os imóveis 
vendidos. 
*/ 
double gerarValorTotalComissaoImoveis (Imovel imoveis[], int contImovel) ( 

double total = 0; 

for (int i=0; i<contImovel; i++) 

total += imoveis[i].getValorComissaoPaga(); 
return total; 


/* 
O método alterarSituaçãoImovel muda a situação de um imóvel. Caso o imóvel mude para 
vendido, a comissão é calculada. Caso o imóvel mude de vendido para qualquer outra 
situação, a comissão recebe zero. 
*/ 
void alterarSituacaoImovel( Imovel imoveis[], int contImovel) { 
int indice; 
string novaSituacao=""; 
double comissaoAux; 
cout << “Digite o índice do imóvel desejado: “; 
cin >> indice; 
if (indice >= 0 && indice < contImovel) ( 
cout << “A situação atual do imóvel é: “ << imoveis[indice].getSituacao() << “. 
“in Digite a nova situaçao (a venda, vendido ou em negociacao): “; 
cin >> novaSituacao; 
while (novaSituacao.compare(imoveis[indice].getSituacao()) == 0) 
{ 
cout << “ERRO! A situação atual do imóvel é: ” << 
= imoveis[indice].getSituacao() << + “. \n Digite a 
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= nova situaçao (a venda, vendido ou em negociacao):”; 


cin >> novaSituacao; 


} 
if (novaSituacao.compare(“vendido”) == 0) { 
cout << “Digite o % da comissão: “; 
cin >> comissaoAux; 
imoveis[indice].setValorComissaoPaga(comissaoAux) ; 
} 
if (novaSituacao.compare(“a venda”) == 0 | | (novaSituacao.compare (“em 
= negociacao”) == 0)) 1 
imoveis[indice].setValorComissaoPaga(0); 
} 
imoveis [indice].setSituacao (novaSituacao) ; 
} 
else { 
cout << “Indice invalido!\n”; 
getchar (); 
} 
} 
int main() { 


Imovel imoveis[30]; 
int opcao, tipo, contImovel=0; 
do { 
opcao = menu(); 
if (opcao == 1) { 
cout << “Escolha o tipo de imóvel: \nl- Casa; 2- Terreno: “; 
cin >> tipo; 
if (tipo==1) { 
Casa auxCasa = geraNovaCasa(); 
contImovel = cadastraNovoImovel (imoveis, contImovel, auxCasa); 


} 
else { 
if (tipo == 2) { 
Terreno auxTerreno = geraNovoTerreno(); 
contImovel = cadastraNovoImovel(imoveis, contImovel, auxTerreno); 
} 
else { 
cout << “Escolha Errada. Observe os tipos de imóveis válidos!\n”; 
+ 
} 


if (opcao == 2) { 
alterarSituacaoImovel(imoveis, contImovel); 


if (opcao == 3) { 
double valorTotalImoveis = gerarValorTotalDosImoveis (imoveis, contImovel); 


cout << “O somatório do valor de venda dos imóveis é ” << valorTotalImoveis << “An”; 


getchar(); 
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} 
if (opcao == 4) { 
double valorTotalComissoes = gerarValorTotalComissaoľImoveis (imoveis, contImovel); 
cout << “O somatório do valor das comissões dos imóveis vendidos é “<< valorTotal 
= Comissoes << “An”; 
getchar(); 


if (opcao == 5) 1 
cout << “Finalizando execucao da aplicacao.”; 


getchar(); 
} 
if (opcao < 1 || opcao > 5) { 
cout << “Opção inválida.”; 
getchar(); 
} 
} while (opcao != 5); 
} 
Resolução em JAVA: 


Arquivo Imovel. java 


/* 
Esta é superclasse de qualquer tipo de imóvel que venha a ser comercializado pela imobiliária. 
E 
public class Imovel { 
private String proprietario; 
private String quadra; 
private int lote; 
private double area; 
private double valorIptu; 
private String situacao; 
private double valorVenda; 
private double valorComissaoPaga; 


public Imovel() { 
super (); 
situacao = new String(“a venda”); 
valorComissaoPaga = 0; 


public String getProprietario() { 
return proprietario; 
public void setProprietario(String proprietario) ( 


this.proprietario = proprietario; 


public String getQuadra() { 
return quadra; 
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public void setQuadra (String quadra) { 
this.quadra = quadra; 


public int getLote() { 
return lote; 


public void setLote(int lote) { 
this.lote = lote; 


public double getArea() { 
return area; 


public void setArea (double area) { 
this.area = area; 


public double getValorIptu() { 
return valorIptu; 


public void setValorIptu(double valorIptu) { 
this.valorIptu = valorIptu; 


public String getSituacao() { 
return situacao; 


public void setSituacao(String situacao) { 
this.situacao = situacao; 


public double getValorVenda() { 
return valorVenda; 


public void setValorVenda (double valorVenda) { 
this.valorVenda = valorVenda; 


public double getValorComissaoPaga() { 
return valorComissaoPaga; 


public void setValorComissaoPaga(double valor) { 
if (valor > 10) 
valor = 10; //limitando a comissão a 10% do valor do imóvel 
this.valorComissaoPaga = valorVenda * valor / 100; 
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Arquivo Casa. java 


/* 
Esta é uma das subclasses de Imovel. Na classe Casa ficam os atributos pertinentes apenas ao objetos 
do tipo Casa, além de seu método próprio para cálculo do IPTU. 
s 
public class Casa extends Imovel { 
private double areaConstruida; 


public Casa() { 
super(); 


public double getAreaConstruida() { 
return areaConstruida; 


public void setAreaConstruida (double areaConstruida) { 
this.areaConstruida = areaConstruida; 


public void calcularIptu() ( 
super.setValorIptu(super.getValorVenda() *1 /100); 


Arquivo Terreno. java 


As 
Esta é uma das subclasses de Imovel. Na classe Terreno não há declaração de atributos, pois todas as 
características necessárias aos objetos desse tipo foram herdadas da superclasse Imovel. 


Contudo, a classe Terreno contém sua implementação própria do cálculo do IPTU. 
=| 


public class Terreno extends Imovel ( 


public Terreno() { 
super(); 


public void calcularIptu() { 
super.setValorIptu(super.getValorVenda() * 2 /100); 


Arquivo Imobiliaria.java 
import javax.swing.JOptionPane; 
public class Imobiliaria ( 


public static void main(String[] args) { 
Imovel imoveis[] = new Imovel[30]; 
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int opcao, tipo, contImovel=0; 
do { 


} 


opcao = menu(); 


if (opcao == 1) { 
tipo = Integer.parseInt (JOptionPane.showInputDialog(“Escolha o tipo de imóvel: 
= \nl- Casa; 2- Terreno")); 
if (tipo==1) { 
Casa auxCasa = geraNovaCasa(); 
contImovel = cadastraNovoImovel( imoveis, contImovel, auxCasa); 
} 
else { 
if (tipo == 2) { 
Terreno auxTerreno = geraNovoTerreno(); 
contImovel = cadastraNovoImovel(imoveis, contImovel, aux Terreno); 
} 
else { 
JOptionPane.showMessageDialog(null, “Escolha Errada. Observe os tipos de 


- imóveis válidos!"); 


if (opcao == 2) 1 
alterarSituacaoImovel (imoveis, contImovel); 


if (opcao == 3) 1 
double valorTotalImoveis = gerarValorTotalDosImoveis (imoveis, contImovel); 
JOptionPane.showMessageDialog(null, “O somatório do valor de venda dos imóveis é 
- “+ valorTotalImoveis); 


if (opcao == 4) { 
double valorTotalComissoes = gerarValorTotalComissaoImoveis (imoveis, contImovel); 
JOptionPane.showMessageDialog(null, “O somatório do valor das comissões dos 


= imóveis vendidos é “+ valorTotalComissoes); 


} 
if (opcao == 5) { 
JOptionPane.showMessageDialog(null, “Finalizando execucao da aplicacao." ); 
} 
if (opcao < 1 || opcao > 5) { 


JOptionPane.showMessageDialog(null, “Opção inválida.”); 


} 


} while (opcao != 5); 
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/* 
O método menu é responsável por mostrar na tela todas as opções e permitir que o usu- 
ário escolha uma delas. 
*/ 
public static int menu() { 
String msg = new String(); 
msg += “1- Cadastrar Imovel An”; 
msg += “2- Alterar situacao de um imóvelin”; 
msg += “3- Somatório do valor dos imóveisn”; 
msg += “4- Somatório do valor das comissõesn”; 
msg += “5- Finalizar execucaoin” ; 
msg += “Digite a opção desejada: “; 
return Integer.parseInt (JOptionPane.showInputDialog(msg)); 
i; 
/* 
O método geraNovoTerreno cria uma nova instância da classe Terreno, atribui valores a 
todos os seus atributos e retorna esse novo objeto. 
*/ 
public static Terreno geraNovoTerreno() { 
Terreno novoTerreno = new Terreno(); 
novoTerreno.setProprietario(JOptionPane.showInputDialog(“Digite o 
- nome do proprietário: “)); 
novoTerreno.setQuadra (JOptionPane.showInputDialog(“Digite a quadra: “)); 
novoTerreno.setLote(Integer.parseInt (JOptionPane.showInputDialog(“Digite o lote: 
22 A 
novoTerreno.setArea (Double. parseDouble(JOptionPane.showInputDialog (“Digite a 
- área:”))); 
novoTerreno.setValorVenda(Double.parseDouble(JOptionPane.showInput Dialog (“Digite 
= o valor de venda: “))); 


return novoTerreno; 


/* 
O método geraNovaCasa cria uma nova instância da classe Casa, atribui valores a todos 
os seus atributos e retorna esse novo objeto. 


*/ 


public static Casa geraNovaCasa() { 
Casa novaCasa = new Casa(); 
novaCasa.setProprietario(JOptionPane.showInputDialog(“Digite o nome do proprietário: “)); 
novaCasa.setQuadra (JOptionPane.showInputDialog(“Digite a quadra: “)); 
novaCasa.setLote( Integer.parseInt (JOptionPane. showInputDialog(” Digite o lote: “))); 
novaCasa.setArea(Double.parseDouble(JOptionPane.showInputDialog(” Digite a área: “))); 
novaCasa.setValorVenda (Double. parseDouble( JOptionPane.showInput Dialog 
- (“Digite o valor de venda: “))); 
novaCasa.setAreaConstruida(Double.parseDouble (JOptionPane.show InputDialog 
- (“Digite a área construída: “))); 


return novaClasa; 


/* 
O método cadastraNovoImovel é responsável por guardar a referência de um novo objeto 


dentro do vetor de imóveis. 
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Importante observar que esse método pode ser utilizado para guardar referência para 
qualquer objeto considerado Imovel, quer seja Terreno, quer seja Casa (polimorfismo). 
*/ 
public static int cadastraNovoImovel (Imovel imoveis[], int contImovel, Imovel auxiliar) { 
if (contImovel < imoveis.length) { 
imoveis[contImovel] = auxiliar; 
contImovel++; 


; 


else JOptionPane.showMessageDialog(null, “Vetor de imóveis já está totalmente 
- preenchido. “); 


return contImovel; 


/* 

O método gerarValorTotalDosImoveis soma o valor de todos os imóveis cadastrados. 

*/ 

public static double gerarValorTotalDosImoveis( Imovel imoveis[], int contImovel) { 
double total = 0; 
for (int i=0; i<contImovel; i++) 
total += imoveis[i].getValorVenda(); 

return total; 


/* 
O método gerarValorTotalComissaoImoveis soma a comissão obtida com todos os imóveis 
vendidos. 
*/ 
public static double gerarValorTotalComissaoImoveis( Imovel imoveis[], int contImovel) { 
double total = 0; 
for (int i=0; i<contImovel; i++) 
total += imoveis[i].getValorComissaoPaga(); 


return total; 


/* 
O método alterarSituaçãoImovel muda a situação de um imóvel. Caso o imóvel mude para 
vendido, a comissão é calculada. Caso o imóvel mude de vendido para qualquer outra si- 


tuação, a comissão recebe zero. 
*/ 
public static void alterarSituacaoImovel( Imovel imoveis[], int contImovel) ( 
int indice; 
String novaSituacao="" ; 
indice = Integer.parseInt (JOptionPane.showInputDialog(“Digite o índice do imóvel 
= desejado: “)); 
if (indice >= 0 && indice < imoveis.length) ( 
- novaSituacao = JOptionPane.showInputDialog(“A situação atual do imóvel é: 
= “ + imoveis[indice].getSituacao()+”. in Digite a nova situaçao 
= (a venda, vendido ou em negociacao)"); 
while (novaSituacao.equalsIgnoreCase( imoveis[indice].getSituacao())) 
$ 
= novaSituacao = JOptionPane.showInputDialog( “ERRO! A situação atual do imóvel é: 
= “ + imoveis[indice].getSituacao()+ “. \n Digite a nova situaçao 


= (a venda, vendido ou em negociacao)"); 
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if (novaSituacao.equalsIgnoreCase(“vendido”)) { imoveis[indice].setValorComissaoPaga 
- (Double.parseDouble (JOptionPane.showInputDialog(“Digite o % da comissão: “))); 


} 
if (novaSituacao.equalsIgnoreCase(“a venda”) || novaSituacao.equalsIgnoreCase 
- (“em negociacao”)) { imoveis[indice].setValorComissaoPaga(0); 
} 
imoveis[indice].setSituacao(novaSituacao); 
i 
else 


JOptionPane .showMessageDialog(null, “Indice invalido!”); 


EA Uma farmácia necessita controlar todos os produtos que comercializa. Sabe-se que nesse estabeleci- 
mento os produtos comercializados são medicamentos e artigos de higiene. Os medicamentos possuem 
código, descrição, preço de compra, percentual de lucro e data de vencimento. Os produtos de higiene 
possuem código, descrição e preço de compra. Sabe-se que todo produto de higiene gera como lucro 
30% do preço de compra. 

Crie classes que representem o contexto descrito. 

Depois disso, você deverá: 

a) Criar um método que permita cadastrar um produto (cadastre um por vez): 
no momento do cadastro deverá ser feita uma verificação para não aceitar códigos repetidos 
(crie um método especificamente para fazer essa verificação); 


o usuário decidirá se deseja cadastrar um medicamento ou um produto de higiene; 
ao final do cadastramento, utilize o método apropriado para calcular o lucro do produto; 


poderão ser cadastrados, no máximo, 15 produtos. 
b) Crie um método para mostrar todas as informações do produto mais caro (pode ser um medicamento ou um 
produto de higiene). 
c) Mostre todos os dados de todos os produtos vendidos na loja. 
d) Crie um método que permita alterar os dados de determinado produto cujo código é informado pelo usuário 


(se for informado código inválido, mostre a mensagem “Produto inexistente”). 
Resolução em C++: 
Arquivo Produto .hpp 


fifndef Produto H 
fdefine Produto H 


include <string> 
using namespace std; 


class Produto ( 
private: 
int codigo; 
string descricao; 
float precoDeCompra ; 
float percentualDeLucro; 


public: 
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Produto(); 

-Produto(); 

int getCodigo(); 

void setCodigo(int codigo); 

string getDescricao(); 

void setDescricao(string descricao); 

float getPrecoDeCompra(); 

void setPrecoDeCompra (float precoDeCompra); 
float getPercentualDeLucro(); 

void setPercentualDeLucro (float percentualDeLucro); 
virtual float gerarPrecoDeVenda(); 

virtual void definirPercentualDeLucro(); 


#endif 


Arquivo Produto.cpp 


#include “Produto .hpp” 
#include <iostream> 


using namespace std; 
Produto::Produto() { 


Produto::-Produto() { 


int Produto: :getCodigo() { 
return codigo; 


void Produto: :setCodigo(int codigo) { 
this->codigo = codigo; 


string Produto: :getDescricao() { 
return descricao; 


void Produto: :setDescricao(string descricao) { 
this->descricao = descricao; 


float Produto: :getPrecoDeCompra() { 
return precoDeCompra; 


void Produto: :setPrecoDeCompra( float precoDeCompra) { 
this->precoDeCompra = precoDeCompra; 
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float Produto: : getPercentualDeLucro() { 
return percentualDeLucro; 


void Produto: :setPercentualDeLucro( float percentualDeLucro) { 
this->percentualDeLucro = percentualDeLucro; 


float Produto::gerarPrecoDeVenda() (>; 


void Produto: :definirPercentualDeLucro() {}; 


Arquivo Higiene.hpp 
fifndef Higiene H 
fdefine Higiene H 


include “Produto.hpp” 
include <string> 


using namespace std; 


class Higiene: public Produto ( 
private: 


public: 

Higiene(); 

float gerarPrecoDeVenda(); 

void definirPercentualDeLucro(); 


+; 
#endif 


Arquivo Higiene .cpp 


#include “Higiene.hpp” 
#include <iostream> 


Higiene::Higiene() { 


float Higiene::gerarPrecoDeVenda() { 
return (getPrecoDeCompra() + getPrecoDeCompra() * 30 / 100); 


void Higiene: :definirPercentualDeLucro() { 
setPercentualDeLucro(30); 


} 


Arquivo Remedio.hpp 


#ifndef _Remedio_H 
#define _Remedio_H 


#include “Produto.hpp” 
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include <string> 
using namespace std; 


class Remedio: public Produto ( 
private: 


public: 

Remedio(); 

float gerarPrecoDeVenda(); 

void definirPercentualDeLucro(); 


#endif 


Arquivo Remedio.cpp 


#include “Remedio.hpp” 
#include <iostream> 


Remedio: :Remedio() { 


float Remedio: :gerarPrecoDeVenda() { 
return (getPrecoDeCompra() + getPrecoDeCompra() * getPercentualDeLucro() / 100); 


void Remedio: :definirPercentualDeLucro() { 
float percAux; 
cout << “Digite o percentual de lucro do produto: “; 
cin >> percAux; 
setPercentualDeLucro(percAux) ; 


Arquivo controledafarmacia.cpp 


include “Produto.hpp” 
#include “Higiene.hpp” 
include “Remedio.hpp” 
include <string> 
include <iostream> 
include <cstdio> 
include <cstdlib> 


using namespace std; 


int menu() { 
int opcao; 
string mensagem; 
mensagem = “\nl- Cadastrar produtoin” ; 
mensagem += “2- Mostrar detalhes do produto mais caroin”; 
mensagem += “3- Mostrar produtos em estoquein” ; 
mensagem += “4- Alterar dados de um produton” ; 
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mensagem += “5- Finalizar programain” ; 
mensagem += “Digite a opcao desejada: “; 
cout << mensagem; 

cin >> opcao; 


return opcao; 


int cadastrarProduto(Produto *p[], int c) { 
int tipo; 
string dataAux; 
do 
{ cout << “inl- para cadastrar Remedio ou 2- para cadastrar produto de Higiene: “; 
cin >> tipo; 
} while (tipo != 1 && tipo != 2); 


if (tipo == 1) { 
Remedio auxiliar; 
string descAux; 
float precoAux, percAux; 
cout << “inDigite descricao do produto: “; 
cin >> descAux; 
cout << “Digite o preco de compra do produto: “; 
cin >> precoAux; 
cout << “Digite o percentual de lucro do produto: “; 
cin >> percAux; 
auxiliar.setCodigo(c+1); 
auxiliar.setDescricao(descAux) ; 
auxiliar.setPrecoDeCompra( precoAux) ; 
auxiliar.setPercentualDeLucro(percAux) ; 


cout << “Preco de Venda = “ << auxiliar.gerarPrecoDeVenda() << “Anin”; 
p[c] = new Remedio; 
*p[c] = auxiliar; 
getchar(); 
} 
else { 


Higiene auxiliar; 
string descAux; 
float precoAux; 
cout << “inDigite descricao do produto: “; 
cin >> descAux; 
auxiliar.setDescricao (descAux) ; 
cout << “Digite o preco de compra do produto: “; 
cin >> precoAux; 
auxiliar.setCodigo(c+1); 
auxiliar.setPrecoDeCompra (precoAux) ; 
auxiliar.setPercentualDeLucro(30); 
cout << “Preco de Venda = “ << auxiliar.gerarPrecoDeVenda() << “Anin”; 
p[c]= new Higiene; 
*p[c] = auxiliar; 
getchar(); 

} 

Chh? 

return c; 

}//fim cadastrarProduto 
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void alterarDadosDeUmProduto(Produto *p[], int c) 1 

int codigo; 

string dataAux; 

cout << “AnDigite o codigo do produto a ter seus dados alterados: “; 
cin >> codigo; 


if (codigo < 1 || codigo-l >= c) { 
cout << “inProduto inexistente!”; 
getchar(); 

} 

else 


{ string descAux; 
float precoAux, percAux; 
cout << “\nDigite nova descricao: “; 
cin >> descAux; 
cout << “Digite novo preco de compra: “; 
cin >> precoAux; 
(*p[codigo-1]).setDescricao (descAux) ; 
(*p[codigo-1]).setPrecoDeCompra (precoAux) ; 
(*p[codigo-1]).definirPercentualDeLucro(); 
cout << “Novo lucro = “ << (*p[codigo-1]).gerarPrecoDeVenda() << “in”; 

} 

getchar (); 

}//fim alterarDadosDeUmProduto 


void mostrarProdutosEmEstoque (Produto *p[], int c) { 


int cont; 

string msg = “"; 

for (cont = 0; cont < c; cont++) 

{ cout << “inCodigo: “ << (*p[cont]).getCodigo(); 
cout << “inDescricao: “ << (*p[cont]).getDescricao(); 
cout << “ínPreco de compra: “ << (*p[cont]).getPrecoDeCompra(); 
cout << “\n% lucro: “ << (*p[cont]).getPercentualDeLucro(); 
cout << “\nLucro: “ << (*p[cont]).gerarPrecoDeVenda() << “An”; 

} 

getchar (); 


}//fim mostrarProdutosVendidos 


void mostrarMaisCaro(Produto *p[], int c) { 
float maiorPreco; 

int indiceDoMaior, cont; 

string msg = “”; 


maiorPreco = (*p[0]).getPrecoDeCompra(); 
indiceDoMaior = 0; 


for (cont = 1; cont < c; cont++) 
{ if ((*p[cont]).getPrecoDeCompra() > maiorPreco) 
{ maiorPreco = (*p[cont]).getPrecoDeCompra(); 
indiceDoMaior = cont; 
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cout << “inCodigo: “ << (*p[indiceDoMaior]).getCodigo(); 

cout << “inDescricao: “ << (*p[indiceDoMaior]).getDescricao(); 

cout << “inPreco de compra: “ << (*p[indiceDoMaior]).getPrecoDeCompra(); 

cout << “\n% lucro: “ << (*p[ indiceDoMaior]).getPercentualDeLucro(); 

cout << “inPreco de venda: “ << (*p[indiceDoMaior]).gerarPrecoDeVenda() << “in”; 
getchar(); 


Y//mostrarMaisCaro 


int main() { 
Produto *produto[15]; 
int opcao, contador = 0; 
do { 
opcao = menu(); 
switch (opcao) 
{ case 1: if (contador == 15) 
cout << “Vetor completamente preenchidoin”; 
else contador = cadastrarProduto (produto, contador); 
break; 
case 2: if (contador == 0) 
cout << “Nenhum produto cadastradoin” ; 
else mostrarMaisCaro(produto, contador); 
break; 
case 3: if (contador == 0) 
cout << “Nenhum produto cadastradoin”; 
else mostrarProdutosEmEstoque (produto, contador); 
break; 
case 4: if (contador == 0) 
cout << “Nenhum produto cadastradoin”; 
else alterarDadosDeUmProduto (produto, contador); 
+ 
} while (opcao != 5); 
}//fim main 


Resolução em JAVA: 
Arquivo Produto. java 


public abstract class Produto ( 
private int codigo; 
private String descricao; 
private float precoDeCompra; 
private float percentualDeLucro; 


public int getCodigo() { 


return codigo; 


public void setCodigo(int codigo) { 
this.codigo = codigo; 


public String getDescricao() { 
return descricao; 
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public void setDescricao(String descricao) { 
this.descricao = descricao; 


public float getPrecoDeCompra() { 
return precoDeCompra; 


public void setPrecoDeCompra( float precoDeCompra) { 
this.precoDeCompra = precoDeCompra; 


public float getPercentualDeLucro() { 
return percentualDeLucro; 


public void setPercentualDeLucro( float percentualDeLucro) ( 
this.percentualDeLucro = percentualDeLucro; 


} 


public abstract float gerarPrecoDeVenda(); 
public abstract void definirPercentualDeLucro(); 


} 


Arquivo Remedio. java 


import javax.swing.JOptionPane; 


public class Remedio extends Produto ( 
public float gerarPrecoDeVenda() { 
return (super.getPrecoDeCompra() + super.getPrecoDeCompra() * 
= super.getPercentualDeLucro() / 100); 


public void definirPercentualDeLucro() { 
super.setPercentualDeLucro(Float.parseFloat (JOptionPane.showInputDialog 
- (“Digite o percentual de lucro do produto”))); 


Arquivo Higiene.java 


public class Higiene extends Produto { 
public float gerarPrecoDeVenda(){ 
return (super.getPrecoDeCompra() + super.getPrecoDeCompra( )*30/100); 


public void definirPercentualDeLucro() { 
super.setPercentualDeLucro(30); 
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Arquivo controledefarmacia. java 


import javax.swing.JOptionPane; 


public class ControleDaFarmacia ( 
public static void main(String[] args) { 
Produto produto[] = new Produto[15]; 
int opcao, contador = 0;; 
do 
{ opcao = menu(); 
switch (opcao) 
{ case 1: if (contador == produto.length) 
JOptionPane.showMessageDialog(null, “Vetor completamente 
- preenchido”); 
else contador = cadastrarProduto(produto, contador); 
break; 
case 2: if (contador == 0) 
JOptionPane.showMessageDialog(null, “Nenhum produto 
œ= cadastrado”); 
else mostrarMaisCaro(produto, contador); 
break; 
case 3: if (contador == 0) 
JOptionPane.showMessageDialog(null, “Nenhum produto 
= cadastrado”); 
else mostrarProdutosEmEstoque (produto, contador); 
break; 
case 4: if (contador == 0) 
JOptionPane.showMessageDialog(null, “Nenhum produto 
= cadastrado”); 
else alterarDadosDeUmProduto (produto, contador); 
} 
} while (opcao != 5); 
}//fim main 


public static int menu(){ 
int opcao; 
String mensagem; 
mensagem = “1- Cadastrar produto\n”; 
mensagem += “2- Mostrar detalhes do produto mais caro\n”; 
mensagem += “3- Mostrar produtos em estoquein” ; 
mensagem += “4- Alterar dados de um produton” ; 
mensagem += “5- Finalizar programa"; 
opcao = Integer.parseInt (JOptionPane.showInputDialog(mensagem) ); 
return opcao; 


public static int cadastrarProduto(Produto p[], int c)f 

int tipo; 

do 

{ tipo = Integer.parseInt (JOptionPane.showInputDialog(“1- para cadastrar Remedio 
= ou 2- para cadastrar produto de Higiene”)); 

} while (tipo != 1 && tipo != 2); 
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if (tipo == 1) 


Remedio auxiliar = new Remedio(); 
auxiliar.setCodigo(c+1); 
auxiliar.setDescricao(JOptionPane.showInputDialog(“Digite descricao do produto”)); 
auxiliar.setPrecoDeCompra (Float.parseFloat (JOptionPane.showInput 

= Dialog(“Digite o preco de compra do produto”))); 
auxiliar.definirPercentualDeLucro(); 


JOptionPane.showMessageDialog(null, “Preco de Venda = “ + 
= auxiliar.gerarPrecoDeVenda()); 
p[c] = auxiliar; 
} 
else { 
Higiene auxiliar = new Higiene(); 
auxiliar.setCodigo(c+1); 
auxiliar.setDescricao(JOptionPane.showInputDialog(“Digite 
- descricao do produto” )); 
auxiliar.setPrecoDeCompra(Float.parseFloat (JOptionPane.show 
- InputDialog(“Digite o preco de compra do produto”))); 
auxiliar.setPercentualDeLucro(30); 
JOptionPane.showMessageDialog(null, “Preco de Venda = “ + 
= auxiliar.gerarPrecoDeVenda()); 
p[c] = auxiliar; 
} 
Cty 
return c; 


}//fim cadastrarProduto 


public static void alterarDadosDeUmProduto(Produto p[], int c) { 


int codigo; 


codigo = Integer.parseInt (JOptionPane.showInputDialog(“Digite o codigo do produto 


= a ter seus dados alterados")); 


if (codigo < 1 || codigo-1 >= c) 


JOptionPane.showMessageDialog(null, “Produto inexistente!”); 


else { 


p[codigo-1].setDescricao(JOptionPane.showInputDialog(“Digite nova 
= descricao”) ); 


p[codigol].setPrecoDeCompra(Float.parseFloat (JOptionPane.showInputDialog 
- (“Digite novo preco de compra”))); 
p[codigo-1].definirPercentualDeLucro(); 
JOptionPane.showMessageDialog(null, “Novo lucro = “ + 

= p[codigo-1].gerarPrecoDeVenda()); 


} 


}//fim alterarDadosDeUmProduto 


public static void mostrarProdutosEmEstoque (Produto p[], int c) { 


int cont; 


String msg = “"; 


for (cont = 0; cont < c; cont++) 


{ msg = msg + “inCodigo: “ + p[cont].getCodigo(); 


msg msg + “AnDescricao: “ + p[cont].getDescricao(); 


msg + “inPreco de compra: “ + p[cont].getPrecoDeCompra(); 


msg 
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msg += “in% lucro: “ + p[cont].getPercentualDeLucro(); 

msg += “ínPreco de venda: “ + p[cont].gerarPrecoDeVenda(); 
JOptionPane.showMessageDialog(null, msg); 

msg = “”; 

} 


}//fim mostrarProdutosEmEstoque 


public static void mostrarMaisCaro(Produto p[], int c) { 
float maiorPreco; 
int indiceDoMaior, cont; 
String msg = “"; 
maiorPreco = p[0].getPrecoDeCompra(); 
indiceDoMaior = 0; 
for (cont = 1; cont < c; cont++) 
{ if (p[cont].getPrecoDeCompra() > maiorPreco) 
{ maiorPreco = p[cont].getPrecoDeCompra(); 
indiceDoMaior = cont; 


} 
} 
msg += “Codigo: “ + p[indiceDoMaior].getCodigo(); 
msg += “\nDescricao: “ + p[indiceDoMaior].getDescricao(); 
msg += “\nPreco de compra: ” + p[indiceDoMaior].getPrecoDeCompra(); 
msg += “\n% lucro: “ + p[indiceDoMaior].getPercentualDeLucro(); 
msg += “\nPreco de venda: “ + p[indiceDoMaior].gerarPrecoDeVenda(); 


JOptionPane.showMessageDialog(null, msg); 
Y//mostrarMaisCaro 


}//fim ControleDaFarmacia 


EXERCÍCIOS PROPOSTOS 


EEB Defina uma classe CARRO com os seguintes atributos: placa e ano de fabricação. Essa classe deve ter também 
um método para calcular o imposto. 


Faça o cadastro de cinco carros, calcule e mostre: 
a) o imposto a ser pago por cada carro, sabendo-se que o cálculo é realizado assim: 


No ano de fabricação, o carro paga R$ 500,00 de imposto. A cada ano de uso, o imposto é reduzido 
em R$ 100,00. Contudo, o valor mínimo a ser pago pelo carro é de R$ 100,00 até o carro atingir o 10º 
ano de uso, quando, então, não precisará mais pagar imposto. As tabelas a seguir mostram exemplos 
de dois carros, um fabricado em 2012 e outro fabricado em 2009. Supondo que o ano atual é 2012, 
estão dispostos o valor dos impostos a serem pagos até 2021. 


Carro fabricado em 2012 Carro fabricado em 2009 
Ano Atual Valor do imposto Ano Atual Valor do imposto 
2012 R$ 500,00 2012 R$ 200,00 
2013 R$ 400,00 2013 R$ 100,00 
2014 R$ 300,00 2014 R$ 100,00 
2015 R$ 200,00 2015 R$ 100,00 
2016 R$ 100,00 2016 R$ 100,00 
2017 R$ 100,00 2017 R$ 100,00 
2018 R$ 100,00 2018 R$ 0,00 
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Carro fabricado em 2012 Carro fabricado em 2009 
Ano Atual Valor do imposto Ano Atual Valor do imposto 
2019 R$ 100,00 2019 R$ 0,00 
2020 R$ 100,00 2020 R$ 0,00 
2021 R$ 0,00 2021 R$ 0,00 


Para cálculo do imposto, o usuário deverá informar o ano atual. 
b) o total dos impostos, ou seja, a soma dos impostos de todos os carros (outro método). 
c) a quantidade de carros que não pagam impostos (outro método). 


IFA Defina uma classe PESSOA com os seguintes atributos: nome e idade. Essa classe deve ter, também, um méto- 
do para calcular a idade em meses. Carregue os atributos anteriores de uma pessoa, calcule e mostre: 


a) a idade da pessoa em meses; 
b) a idade que a pessoa terá em 2050 (outro método). 


BEM Defina uma classe denominada PRODUTO com os seguintes atributos: número do produto e preço do pro- 
duto. Essa classe deve possuir, também, um método para calcular o valor do desconto, ou seja, produtos com 
preço superior a R$ 100,00 possuem desconto de 15% e os demais produtos têm desconto de 5%. 


Defina uma classe CLIENTE com os seguintes atributos: número do cliente, nome do cliente e sexo do 
cliente. Essa classe deve possuir, também, um método para calcular o desconto adicional, ou seja, clientes 
do sexo feminino (F ou f) têm um desconto adicional de 5% sobre o preço do produto e os demais clientes 
(M ou m) não possuem esse desconto. 

Defina uma classe denominada COMPRA com os seguintes atributos: número do produto, número 
do cliente, quantidade e valor total. Essa classe deve possuir ainda um método para calcular o valor total, 
ou seja, a quantidade multiplicada pelo preço final. O preço final é o preço do produto menos o desconto 
adicional, quando este existe. 

Faça um programa que carregue três produtos validando apenas o preço para que este esteja entre R$ 
20,00 e R$ 350,00. Carregue três clientes validando para que o sexo seja M, m, F ou f. E, por fim, carregue 
uma compra digitando um número do produto, um número do cliente e a quantidade comprada do produto 
e calculando o valor total (método da classe COMPRA). Suponha sempre a digitação de dados válidos. 


ES Crie uma aplicação para a secretaria de uma escola, em que sejam controladas as informações sobre Alunos, 
Disciplinas e Matrículas. 


Antes de a escola começar a funcionar, todas as disciplinas foram cadastradas. 


Quando o aluno chega à escola, deve ser feito um cadastro dos seus dados pessoais. Só depois, ele é, 
anualmente, matriculado em disciplinas. 


Os atributos das classes são: 


Aluno (código, nome) 

Disciplina (código, nome, carga horária geral) 

DisciplinaPratica (carga horária prática) 

Matricula (ano letivo, serie, aluno, disciplina, notal Bim, nota2Bim, nota3Bim, nota4Bim) 


O atributo aluno na classe Matricula deve ser uma referência para a classe Aluno. 

O atributo disciplina na classe Matricula deve ser uma referência para a classe Disciplina. 

A DisciplinaPratica deve possuir todas as características da classe Disciplina, mais as suas especificida- 
des (herança). 


Essa aplicação deve fornecer meios para: 

a) Cadastrar as disciplinas oferecidas na escola (práticas ou não). 
b) Cadastrar alunos. 

c) Matricular aluno em uma disciplina qualquer. 
d) Lançar notas de um aluno. 
) 


e) Mostrar Boletim do aluno. 
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Você deverá possuir um conjunto de alunos, de disciplinas e de matrículas. Como sugestão, trabalhe 
com, no máximo, dez alunos, cinco disciplinas e trinta matrículas (controle o preenchimento máximo). 


Para a opção 1: 

Cadastre uma disciplina por vez (prática ou não). O código deverá ser único. 

Deverá existir um único vetor de disciplinas para referenciar tanto disciplinas sem prática quanto dis- 
ciplinas práticas. 

O usuário, durante a execução, decidirá se deseja cadastrar uma disciplina prática ou não. 


Para a opção 2: 
Cadastre um aluno por vez. O código deverá ser único. 


Para a opção 3: 

Matricule um aluno em uma disciplina (prática ou não) por vez. 

Aluno e Matrícula já devem ter sido cadastrados. 

Não matricule um aluno mais que uma vez, na mesma disciplina, no mesmo ano. 
No momento da matrícula, o valor das notas deverá ser zero. 


Para a opção 4: 

O usuário deverá informar o código do aluno, o código da disciplina, o ano e o bimestre. Se houver 
alguma matrícula com essas características, solicitar a digitação da nota correspondente, alterando o objeto. 
Caso contrário, mostrar a mensagem Matrícula Inválida. 


Para a opção 5: 

O usuário deverá informar o código do aluno e o ano. A aplicação deverá procurar os dados corres- 
pondentes e mostrar um relatório, conforme abaixo. Caso os dados informados não correspondam a uma 
matrícula, mostrar a mensagem Matrícula Inválida. 


Código: 1234 Nome: Joãozinho 


Ano: 2011 
Disciplina CH CH prática 1º Bim. 2º Bim. 3º Bim. 4º Bim. Média 
Inglês 100 40 5,0 7,0 10,0 7,5 
Português 140 8,0 8,0 9,0 70 8,0 
Matemática 160 40 3,0 7,0 9,0 6,0 6,33 
Geografia 80 8,5 9,5 6,0 7,0 7,75 


Disciplinas práticas têm cálculo de média ponderada, em que as notas do 2º e 4º bimestres possuem 
peso 2 e as demais, peso 1. Para as outras disciplinas, a média é aritmética. 


EA O departamento de pessoal de uma empresa deseja automatizar o cadastro dos funcionários. Para isso, repas- 
sou os seguintes requisitos à equipe de analistas contratada: 


É necessário o cadastramento dos funcionários e seus respectivos dependentes. Suas características são: 
Funcionário: numeroFuncionario, nomeFuncionario, cargo, salário. 

Dependente: funcionario (referência para um objeto da classe Funcionario), nomeDependente. 

Existem diversos funcionários com quantidade diferenciada de dependentes. 

Sua aplicação deverá mostrar as seguintes opções ao usuário: 


1) Cadastrar funcionário 


Cada vez que essa operação for realizada, você deverá criar um novo objeto Funcionário, preencher 
seus dados e inseri-lo no conjunto de funcionários da empresa. 

O código do funcionário deve ser único. 

Logo após, deverá realizar o cadastro de dependentes. Isso implica na criação de vários objetos da 
classe Dependente e inseri-los no conjunto de dependentes (cada funcionário pode ter zero, um ou mais 
dependentes. O usuário dará essa quantidade). 

Você deverá verificar se há espaço nos vetores para esses cadastramentos. 
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2) Mostrar bônus mensal de cada funcionário 


Os funcionários têm 2% de aumento em seu salário para cada dependente. Por isso, mostre o nome de 
cada funcionário, seguido da quantidade de dependentes que possui e do bônus a quem tem direito. 


3) Excluir funcionário 


Você deverá excluir da lista um funcionário cujo código será informado pelo usuário. 

Todos os dependentes desse funcionário também deverão ser excluídos. 

Caso o funcionário informado não esteja cadastrado, mostre uma mensagem de erro “Funcionário 
Inexistente”. 


4) Alterar salário de um funcionário 


Em cada posição do conjunto de funcionários, existe um objeto Funcionario. Considerando que os 
objetos funcionários possuam o método setSalario, você deverá procurar um funcionário (cujo código é 
informado pelo usuário) e alterar o seu salário. 

O valor do novo salário também deverá ser informado pelo usuário. 

Caso o funcionário informado não esteja cadastrado, mostre uma mensagem de erro “Funcionário 
Inexistente”. 


OBSERVAÇÕES: 
todos os atributos das classes devem ser private; 
cada atributo deve ter um método getter e um setter; 


CAPÍTULO 


3 Desafios 


13.1 Desafio | 


Segundo o dicionário, a palavra PONTE é definida na ARQUITETURA como uma construção sólida 
em betão, aço ou madeira, destinada a estabelecer comunicação entre dois pontos separados por um curso 
de água ou por uma depressão de terreno. 

A atual presidente da República vai beneficiar alguns estados do BRASIL com a construção de obras de 
grande magnitude e nosso estado será agraciado com uma ponte suspensa que será considerada um marco 
na construção civil, que ligará o estado de Mato Grosso do Sul ao estado de São Paulo. 

Veja a foto a seguir com um exemplo de ponte suspensa já existente em Porto Alegre (RS) e que se difere 
da obra a ser construída, pois na ponte ilustrada, o material usado na sustentação foi uma corda especial, e 
isso impossibilita a passagem de veículos pesados. Assim, como o tráfego previsto para a ponte a ser cons- 
truída envolve todo tipo de veículo, serão utilizados cabos de aço importados da ALEMANHA. 

À seguir, apresentamos o projeto da ponte a ser construída. 


Cabos de aço 


Haste de sustentação pS E Haste de sustentação 


Parte terrestre 
do Estado de 


Parte terrestre 
do Estado de 


Ponte suspensa 
São Paulo Mato Grosso 


do Sul 


O comprimento da ponte suspensa será fornecido pelo usuário em quilômetros e deve estar entre 2 e 
4. Sabe-se que a ponte terá quatro hastes de sustentação, duas na parte terrestre do estado de Mato Grosso 
do Sul e outras duas na parte terrestre do estado de São Paulo, e estas ficam nas margens direita e esquerda. 
Tem-se, ainda, que a altura da haste, e onde deve ser fixado o cabo de aço mais alto, deve ser de '/,, da ex- 
tensão da ponte. O cabo de aço mais alto será fixado obrigatoriamente no meio da ponte. Cada haste, num 
total de quatro, sustentará cinco cabos de aço equidistantes. 

Faça um programa para calcular quantos metros de cabos de aço serão necessários para construir a ponte 


suspensa. 
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13.2 Desafio 2 


Uma fábrica de brinquedos precisa produzir alvos feitos de papelão. Para tal 
produção, será necessário adquirir o material, ou seja, o papelão. Assim, a fábrica 
solicitou à equipe de desenvolvimento que fizesse um programa para calcular a 
quantidade de papelão a ser comprada para a confecção de 5 mil alvos. Sabe-se 
que o brinquedo terá seis círculos sobrepostos e que todos os círculos apresentam 
a mesma distância do círculo imediatamente menor. O diâmetro do círculo maior 
será dado pelo usuário. 


13.3 Desafio 3 


Uma pessoa deseja colocar pregos a determinada altura do chão. Para isso, deverá comprar uma escada 
e apoiá-la na parede. Essa escada formará um ângulo conhecido como chão. Pelas especificações do Inme- 
tro, todas as escadas produzidas no Brasil têm uma distância de 30 centímetros entre os degraus. Assim, 
deve-se construir um programa para saber que tipo de escada comprar, ou seja, quantos degraus deve ter 
a escada para que a altura do prego seja atingida, mesmo que aproximadamente. Desconsidere a altura da 
pessoa que fará o serviço. 


Distância padrão entre degraus = 30 centímetros 


Modelo de escada com 4 degraus 


Escada aprovada pelo Inmetro 


Altura em que os pregos devem ser 
colocados em metros 


Ângulo, em graus, que a escada forma com 
o chão ao ser apoiada na parede 


13.4 Desafio 4 


Um problema típico em ciência da computação consiste em converter um número da sua forma decimal 
para a forma binária. Por exemplo, o número 12 tem sua representação binária igual a 1.100. A forma mais 
simples de fazer isso é dividir o número sucessivamente por 2, cujo resto da i-ésima divisão vai ser o dígito 
i do número binário (da direita para a esquerda). 

Por exemplo: 12 / 2 = 6, resto O (1º dígito da direita para esquerda), 6 / 2 = 3, resto 0 
(2º dígito da direita para esquerda), 3/2 = 1 resto 1 (3º dígito da direita para esquerda), 1/2 = 0 resto 1 (4º 
dígito da direita para esquerda). Resultado: 12 = 1100. 
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13.5 Desafio 5 


Um escritório de engenharia está fazendo os cálculos de quanto gastará com a mão de obra dos seus 
pedreiros. Sabe-se que cada pedreiro ganha 10% do valor do salário mínimo por metro quadrado de cons- 
trução. Logo, para a construção de um condomínio fechado com 40 casas, tem-se, para cada casa, apenas 
um pedreiro trabalhando, e cada casa tem a planta a seguir. Calcular e mostrar o custo da mão de obra do 


condomínio. 
Altura = L*0.7 


COPA e 


2XL COZINHA 


Diâmetro = L/2 


13.6 Desafio 6 


Faça um programa que receba um número entre 1 e 10.000 e mostre o valor digitado por extenso. 


digite um número: 10.500 
número inválido 

digite um número: 130 
cento e trinta 


digite um número: 5 
cinco 


digite um número: 1.259 
um mil e duzentos e cinquenta e nove 


13.7 Desafio 7 


Faça um programa que simule um jogo de forca. 


Restrições: 

1. Devem ser previamente cadastradas dez palavras. 
2. Com cada palavra deve ser cadastrada uma dica. 
3. A palavra a ser acertada deve ser sorteada. 
4 


Quando o usuário tiver só mais uma chance, a dica deve ser apresentada. 
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No total, o usuário deve ter no máximo sete chances. 
Letras maiúsculas e minúsculas devem ser aceitas. 


O usuário pode jogar quantas vezes quiser. 


Sopa a 


As letras já testadas devem ser mostradas e não podem ser testadas mais de uma vez. 


13.8 Desafio 8 


Faça um programa que apresente o menu de opções a seguir: 


Cadastrar pessoa na agenda de aniversariantes (nome, dia e mês do aniversário). 
Excluir pessoa a partir do nome. 

Alterar dia ou mês a partir do nome. 

Consultar aniversariantes de uma data (dia e mês). 


Consultar aniversariantes por mês. 


Mostrar toda a agenda ordenada pelo nome. 
Mostrar toda a agenda ordenada por mês. 


1 
2 
3 
4 
5 
6. Consultar aniversariantes pela letra inicial do nome. 
7 
8 
9. Sair. 

A 


agenda pode suportar até 15 pessoas. 


13.9 Desafio 9 


Faça um programa que carregue três vetores nos quais serão armazenados os códigos, os salários e o 
tempo do serviço, em anos, de cinco funcionários. Posteriormente, o programa deverá: 


a) Receber um valor que corresponde ao salário a ser consultado e, em seguida, mostrar dois relató- 
rios. Cada relatório deverá mostrar o código do funcionário e o salário. O primeiro relatório deve 
mostrar os funcionários que têm salário até o valor digitado e o segundo relatório deve mostrar os 
funcionários que possuem salário superior ao valor digitado. Caso não exista nenhum funcionário 
em algum dos relatórios, mostrar mensagem. 


b) Encontrar o menor salário pago, calcular e mostrar quantos funcionários têm salário igual ao me- 
nor salário e, posteriormente, mostrar os códigos desses funcionários. 


c) Gerar e mostrar um quarto vetor com os códigos dos funcionários que possuem tempo de serviço 
entre 2 e 4 anos e são isentos de impostos. Sabe-se que os funcionários isentos de impostos são 
aqueles que possuem salário inferior a R$ 1.500,00. Caso nenhum funcionário preencha os requi- 
sitos, mostrar mensagem. 


13.10 Desafio 10 


Faça um programa que apresente o menu de opções a seguir: 


Incluir um número no vetor. 
Consultar todos os números do vetor. 
Consultar um número do vetor. 
Excluir um número no vetor. 


Esvaziar o vetor. 


Oyo ISA cega O gi 


Sair. 
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Todas as operações anteriores devem ser realizadas em um vetor de dez posições e o vetor pode conter 
números repetidos, que podem ser desordenados. 


13.11 Desafio 11 


Faça um programa que apresente o menu de opções a seguir: 
Incluir um número no vetor. 

Consultar todos os números do vetor. 

Consultar um número do vetor. 

Excluir um número no vetor. 


Esvaziar o vetor. 


Onda ho dial S 


Sair. 


Todas as operações anteriores devem ser realizadas em um vetor de dez posições e o vetor não pode 
conter números repetidos, que devem estar ordenados. 


13.12 Desafio 12 


Uma empresa do ramo da construção civil está informatizando seu Departamento de Pessoal. 
Inicialmente, cadastrou o salário de todos os cargos da empresa. 
1 2 3 4 5 
Cargos R$ 2.500,00 R$ 1.500,00 R$ 10.000,00 R$ 1.200,00 R$ 800,00 


Cada tipo de cargo ocupa uma posição do vetor de tamanho 5. 
Depois, cadastrou todos os seus funcionários em um vetor de registros, contendo os seguintes campos: 
código, nome e código do cargo. 


1 2 5 4 5: 

codigo 15 1 26 12 8 
nome João da Silva | Pedro Santos | Maria Oliveira | Rita Alcântara Lígia Matos 

codigo cargo 1 2 3 5 2 


Crie uma aplicação que contenha uma função para mostrar um menu ao usuário, assim: 

1. Cadastrar os cargos da empresa. 

Cadastrar os funcionários da empresa. 

Mostrar um relatório contendo o número, o nome e o valor do salário de todos os funcionários. 


Mostrar o valor pago aos funcionários que pertençam a um cargo informado pelo usuário. 


SA TRE DS 


Finalizar. 


Opção 1: Cada vez que essa opção for selecionada deverá ser chamada uma sub-rotina, na qual o usuário 
poderá cadastrar todos os cargos. Não se esqueça, nessa empresa existem apenas cinco cargos. Se o usuário 
mandar executar esta opção mais de uma vez, mostre a mensagem de erro “Salários dos cargos já cadastra- 
dos” e retorne ao menu. 


Opção 2: Cada vez que essa opção for selecionada deverá ser chamada uma sub-rotina, na qual o usuário 
poderá cadastrar um novo funcionário, ou seja, informará o número do funcionário (este número deve ser 
único, você deverá implementar essa validação), nome e código do cargo (lembre-se de que o código infor- 
mado deverá existir no vetor de cargos). Não se esqueça, nessa empresa existem apenas 15 funcionários. Se 
o usuário selecionar essa opção e o vetor de funcionários estiver completamente preenchido, mostrar uma 
mensagem de erro e retornar ao menu. 


Crie uma sub-rotina para fazer a validação do número do funcionário — ela não poderá aceitar 
número repetido. 
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Crie uma sub-rotina para validar o nome do funcionário, obrigando-o a ser composto por pelo 
menos duas palavras (nome e sobrenome). 


Crie uma sub-rotina para fazer a validação do código do cargo ocupado pelo funcionário — ela 
só poderá aceitar códigos entre 1 e 5 cujos salários já tenham sido cadastrados no vetor de cargos. 


Opção 3: Cada vez que essa opção for selecionada deverá ser chamada uma sub-rotina, na qual serão mos- 
trados código, nome e valor do salário de todos os funcionários cadastrados (salários podem ser obtidos no 
vetor de cargos). 

Opção 4: Cada vez que essa opção for selecionada deverá ser chamada uma sub-rotina, na qual será feito 
o somatório do salário de todos os funcionários que pertencerem a determinado cargo. Esse cargo é infor- 
mado pelo usuário (entre 1 e 5) no módulo principal do seu programa e o somatório calculado deverá ser 
mostrado, também, no módulo principal. 


13.13 Desafio 13 


Alguns números inteiros possuem a capacidade de se autoelogiarem através de seus dígitos. Estes são 
números que formam a família dos Números Narcisistas. Os Números Narcisistas clássicos são aqueles 
iguais à soma de cada um de seus dígitos elevados à potência do número total de dígitos. 

Por exemplo, o número 153 é um narcisista clássico porque a soma de cada um de seus dígitos elevados 
ao cubo (total de dígitos que compõem o número 153) é exatamente 153. 


153=12+5º+3º=1+125+27=153 


Crie um programa que receba um número qualquer e determine se ele é Narcisista ou não. 


13.14 Desafio 14 


Dois números são considerados AMIGÁVEIS se um deles corresponder à soma dos divisores (exceto o 
próprio número) do outro. 

Por exemplo: vamos analisar os números 8 e 10. 

Os divisores de 8 são: 1, 2 e 4, resultando em soma igual a 7. 

Já os divisores de 10 são: 1,2 e 5, resultando em soma igual a 8. 

Assim, como a soma dos divisores de 10 (exceto ele próprio) resulta em 8, pode-se dizer que os números 
10 e 8 são amigáveis. 


Criar um programa que receba dois números inteiros quaisquer e determine se são amigáveis ou não. 


13.15 Desafio 15 


Uma escola oferece 3.058 cursos. Sabe-se que cada curso possui descrição, quantidade de alunos matri- 
culados e valor da mensalidade. A escola precisa cadastrar os cursos e, depois, precisa saber: 


a) a média aritmética de alunos matriculados nos cursos; 


b) a descrição do curso que gera a maior receita (receita = quantidade de alunos * valor da men- 


salidade). 


Crie uma aplicação que, utilizando um vetor de registro, consiga atender as necessidades da escola. 


13.16 Desafio 16 


Uma universidade deseja fazer a apuração do resultado do vestibular dos cursos de Ciência da Compu- 
tação, Engenharia de Computação e Análise de Sistemas. 

Para isso, contabilizará o total de pontos obtidos pelos candidatos e armazenará em uma matriz 3 x 40, 
onde a linha representa o curso (12 linha Ciência da Computação, 22 linha Engenharia de Computação e 32 
linha Análise de Sistemas). 

Cada célula da matriz deverá conter o código do candidato e sua pontuação. 

Considerando que cada curso possui apenas quarenta vagas, nessa matriz deverão ficar armazenadas 
as informações apenas dos quarenta melhores candidatos. 
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Enquanto o curso possuir menos de quarenta candidatos cadastrados, qualquer inserção será aceita 
(aconselha-se a inserção em ordem decrescente de pontuação). Quando já existirem quarenta candidatos em 
determinado curso e for digitada uma pontuação maior que a do último colocado, este deverá ser eliminado 
para que o novo candidato seja inserido na matriz. 

Criar uma aplicação que digite diversas pontuações e, ao final, mostre o código e a pontuação dos 
quarenta aprovados em cada curso. 


13.17 Desafio 17 


Uma empresa de telefonia adotou um sistema de cobrança cujo valor do minuto de uma ligação varia 
de acordo com o horário de início: 


das Oh às 9h — 50% de desconto no valor do minuto. 

das 9h01 às 18h — 0% de desconto no valor do minuto. 

das 18h01 às 21h — 30% de desconto no valor do minuto. 
das 21h01 às 23h59 — 40% de desconto no valor do minuto. 


Faça um programa que receba o horário inicial (hora e minuto) e o horário final (hora e minuto), junto 
com o valor normalmente cobrado pelo minuto de uma ligação. 

De acordo com os dados anteriores, aplique corretamente os descontos e mostre o valor normal a ser 
cobrado e o valor com o desconto concedido. 


see Observação 


Se a ligação começou em uma faixa de desconto e terminou em outra, você deverá calcular o 
desconto de acordo com o período de duração da ligação em cada faixa. Por exemplo, se uma li- 
gação começou às 8h30 e terminou às 20h, você deverá conceder 50% de desconto para o período 
de 8h30 até as 9h, 0% de desconto para o período de 9h01 até as 18h e 30% de desconto para o 
período de 18h01 até as 20h. 


13.18 Desafio 18 


Você foi contratado para trabalhar em uma empresa de segurança e está encarregado de registrar os 
nomes de várias pessoas suspeitas de corrupção. 

Temendo que esse arquivo caia em mãos erradas, você decidiu que as informações deveriam ser cripto- 
grafadas antes da gravação e somente pessoas autorizadas possuirão mecanismos para descriptografá-las. 

Assim, implemente uma aplicação que grave em um arquivo de texto uma quantidade indeterminada 
de dados, no seguinte padrão: 


caracterel; caractere2; informação1;informação2& 
caracterel; caractere2; informação1;informação2;informação3 & 


O símbolo ; separa dados de uma mesma pessoa. O símbolo & separa uma pessoa de outra. 

O objetivo dessa aplicação é fazer o trabalho de criptografar/descriptografar. 

Para cada pessoa, solicite o caracterel e o caractere2. Eles serão a base para o processo de criptograr/ 
descriptografar. 

Quando as informações de uma pessoa forem recebidas, todos os símbolos contidos na informação, 
iguais ao caractere2, deverão ser substituídos pelo caractere1 e, só então, a gravação deverá ser realizada 
no arquivo. 

A gravação dos dados termina quando for fornecido o símbolo @ como entrada. 

Quando uma leitura for feita, todos os símbolos contidos na informação iguais ao caracterel deverão 
ser substituídos pelo caractere? para, só então, serem mostrados ao usuário. 

Mostre todos os dados gravados (descriptogrados). 


554 | Fundamentos da programação de computadores 


13.19 Desafio 19 


Um médico está melhorando o processo de agendamento de consultas, a fim de evitar transtornos de- 
correntes de esquecimentos de sua secretária. 

Basicamente, o médico precisa de: 

1. Cadastramento de pacientes (código, nome paciente, nome convênio, telefones fixo e celular). 
Não podem existir pacientes com código repetido. Criar um arquivo, chamado paciente.dat. 

2. Agendamento (data, hora, código do paciente, tipo consulta — Normal ou Retorno). 
Não podem existir duas consultas agendadas para o mesmo dia e horário. Criar um arquivo chama- 
do agenda.dat. 

3. Alteração de pacientes. 
Informe o código do paciente. Se encontrar paciente gravado no arquivo de Pacientes, altere seus 
dados. Usar o arquivo paciente.dat gerado no item 1. 

4. Visualização de consultas. 
Mostre todas as consultas agendadas (inclusive o nome do paciente). Usar os arquivos paciente.dat 
e agenda.dat, criados nos itens 1 e 2. 

5. Geração de arquivo auxiliar 
Paralelamente ao seu trabalho, outra empresa está desenvolvendo uma aplicação que, no dia da 
consulta, envia uma mensagem ao telefone celular do paciente, alertando-o sobre o horário agen- 


dado com o médico. Você, então, deverá gerar para essa aplicação um arquivo de texto, contendo 
nome do paciente, data da consulta e horário da consulta (separe cada dado por um hífen). 


13.20 Desafio 20 


Uma rede de lanchonete está implantando um sistema informatizado de controle de estoque. Cada filial 
dessa rede segue um padrão rigoroso, em que todos os lanches utilizam os mesmos ingredientes, gerando, 
assim, a mesma lista de produtos em estoque. 

É interessante manter cadastrados descrição, quantidade em estoque, quantidade mínima exigida e 
valor unitário de cada produto. Cada filial possui seis produtos em estoque. 

Para o efetivo cadastramento, os projetistas do sistema sugeriram aos programadores a utilização de 
um vetor de seis posições para o cadastramento da descrição dos produtos e uma matriz 6 x 3 para cadas- 
trar quantidade em estoque, quantidade mínima exigida e valor unitário. 


1 2 5 4 5 6 
Matiz de Pão com Alface Tomate Queijo Hambúrguer Nuggets 
descrição gergelim americana Cheddar 
1 2 3 
10 5 12 1 
20 8 2.3 2 
; 15 4 2.7 3 
Matriz com valores 
numéricos 25 15 30.5 E 
100 60 Sxl 5 
200 50 2.8 6 
Quantidade em Quantidade mínima Valor unitário 
estoque exigida 


Seguindo o definido em projeto, você foi contratado para implementar as seguintes funcionalidades, 
acessadas por meio de um menu de opções: 


1. Cadastrar as informações dos seis produtos, atendendo às seguintes restrições: 
a) a quantidade em estoque não poderá ser inferior à quantidade mínima exigida; 
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b) o valor unitário deverá ser maior que zero — caso seja informado algum valor incorreto, mos- 
tre uma mensagem de erro e solicite-o novamente. 


2. Retirar um produto do estoque: você deverá informar o nome do produto desejado e a quantidade 

desejada. 

Então, deverá procurar o produto no vetor de descrições. Se ele não existir, mostrar uma mensagem 
de erro e voltar ao menu de opções. Se o produto existir, você deverá verificar se a quantidade em estoque 
é suficiente para atender à solicitação. Se a quantidade existente for suficiente, deverá ser atualizada (por 
exemplo, se o produto pão com gergelim possui 10 unidades em estoque e vou utilizar 3, deverei atualizar 
a quantidade em estoque para 7). Se a quantidade existente não for suficiente para atender à solicitação, 
mostrar a mensagem “Estoque insuficiente” e voltar ao menu de opções. 


3. Mostrar a descrição de todos os produtos com quantidade em estoque inferior ao estoque mínimo 
exigido. 
4. Mostrar o valor total dos produtos existentes no estoque. 


13.21 Desafio 21 


Uma empresa necessita criar um software capaz de controlar as vendas realizadas, com o objetivo de 
gerar alguns relatórios que auxiliem no processo de reposição de estoque. 
À empresa detectou que precisa ter acesso rápido a algumas informações: 


quantidade vendida de determinado produto em um período; 
faturamento em determinado período (somatório das vendas realizadas); 
valor recebido em um período; 

produtos com estoque abaixo do mínimo exigido; 


lucro do período (para definir o lucro, deve ser descoberta a quantidade vendida de cada produto 
para fazer a diferença entre o valor cobrado do cliente e o valor pago ao fornecedor). 


Para atender a essas solicitações, uma equipe de analistas definiu a necessidade de criar alguns arquivos 
para armazenamento permanente de dados, os quais permitirão a geração dos relatórios descritos anterior- 
mente: 


Arquivo Produtos: nesse arquivo, deverão ficar registrados todos os produtos comercializados pela empre- 
sa: código único do produto, descrição (String de 30 caracteres), valor de compra, valor de venda, estoque 
mínimo exigido estoque atual. 


Arquivo Cliente: nesse arquivo, deverão ficar registrados os dados dos clientes que podem realizar compras 
a prazo: código único do cliente, nome do cliente, endereço telefone. 


Arquivo Vendas: nesse arquivo, deverão ficar registrados dados das vendas: número da venda, data da 
venda, tipo da venda (à vista ou a prazo), código do cliente (se a venda for a prazo, preencher esse campo 
com um cliente válido, caso contrário preencher este campo automaticamente com —1) e data do venci- 
mento (se a venda for à vista, esse campo deve ser preenchido automaticamente com a data da venda, 
caso contrário, solicitar uma data igual ou superior à data da venda). 


Arquivo Item de Vendas: considerando que uma venda pode estar associada a vários produtos, é neces- 
sário criar um arquivo que relacione o arquivo Vendas com o arquivo Produtos. Nesse arquivo, deverão 
ser gravados: número da venda, código do produto, quantidade vendida, valor da venda (para descobrir 
o valor que um cliente pagou por um produto no passado). 

À estrutura dos arquivos pode ser representada conforme mostrado na próxima página: 
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Representação do arquivo Clientes 


Código g 
; 8 Nome cliente Endereço Telefone 
cliente 
2 Manoel Rua da padaria 1111-2222 
1 Rua da farmácia 3333-4444 


5 Rua do hospital 1234-5678 
10 Rua do supermercado 4321-0000 
Representação do arquivo Vendas 
Número da Código Data 
Data venda RE : 
venda cliente vencimento 
—> |1 11/06/2010 Prazo 2 11/07/2010 
2 15/06/2010 Vista —1 15/06/2010 
3 20/08/2010 Vista =] 20/08/2010 
4 25/08/2010 Prazo 5 25/10/2010 
Representação do arquivo Itens De Vendas 
Número da E Qtde. 
Código produto A Preço pago 
venda 80 P vendida 70 pag 
>i 2 5 2,70 
> 1,30 
1 20 1,50 
1 5 1,50 
2 10 2,00 
5 1,10 
2 3,00 
Representação do arquivo Produtos 
ódigo Descrição Valor tde. Estoque 
8 E Valor compra E 3 q 
produto produto venda estoque mínimo 
Lápis 1,00 2,00 100 20 
Caneta 2,00 3,00 80 15 
Apontador 0,50 1,30 200 30 


Seu trabalho como programador é implementar uma aplicação, usando arquivos, que permita mostrar 
um menu de opções, para que o usuário decida o que deseja fazer: manutenção no arquivo de produto, 
manutenção no arquivo de cliente, manutenção no arquivo de venda, realizar consultas, ou encerrar a exe- 
cução da aplicação. 

1. Para manutenção de produtos 


Fornecer as seguintes opções: 


Cadastrar novo produto: gerar o código único automaticamente, receber as demais informações do 
produto e gravar tudo no arquivo correspondente. 


Consultar produto: solicitar que o usuário informe o código do produto desejado e buscá-lo no 
arquivo. Caso o encontre, mostrar todas as suas informações. Caso não o encontre, mostrar uma 
mensagem de erro e retornar ao menu Manutenção de Produtos. 


Excluir produto: solicitar que o usuário informe o código do produto desejado e buscá-lo no arqui- 
vo. Caso não o encontre mostre mensagem de erro. Se o encontrar, verifique, então, se tal produto 
foi usado em alguma venda. Se sim, mostre uma mensagem informando que a exclusão não poderá 
ser realizada. Se o produto não estiver vinculado a nenhuma nota, efetive a exclusão. 
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Alterar produto: solicitar que o usuário informe o código do produto desejado e buscá-lo no arqui- 
vo. Caso ele não exista, mostrar mensagem de erro. Caso exista, sobrepor todos os dados com os 
novos valores fornecidos pelos usuários. 


2. Para manutenção de clientes 


Disponibilizar as mesmas funções do menu de Manutenção de produtos. 
3. Para realização de vendas 


Gerar o número da Nota Fiscal de venda automaticamente. A data da emissão da Nota fiscal deverá 
ser capturada do sistema. O tipo da venda deverá ser fornecido pelo usuário, podendo ser “à vista” ou “a 
prazo”. 

Caso o usuário opte por venda a prazo, deverão ser fornecidos o código do cliente (que deverá ter sido 
previamente cadastrado no arquivo de clientes) e data de vencimento (que deverá ser igual ou superior à 
data da emissão da Nota Fiscal). 

Caso as informações estejam todas corretas, gravar os dados no arquivo Notas e permitir que o usuário 
cadastre diversos produtos nessa nota (gravando-os no arquivo ItensDeVendas). 

O usuário fornece o código do produto (que deverá ter sido previamente cadastrado no arquivo de 
produtos) e a aplicação mostra a descrição correspondente. 

Não permita vender quantidade maior que a registrada no arquivo de produtos. Ao confirmar a venda, 
atualizar o estoque. 


4. Consultas 


Permitir que sejam realizadas as seguintes consultas: 


Número das vendas realizadas em determinado período informado pelo usuário. 


Código e descrição dos produtos com quantidade em estoque abaixo do estoque mínimo permitido. 


13.22 Desafio 22 


Crie uma aplicação que simule o jogo descrito a seguir: 

É o conhecido jogo da cobrinha com algumas pequenas alterações. 

Você deverá criar uma janela com as dimensões que desejar. Dentro dessa janela deverão ser colo- 
cados dois tipos de elementos: comida para a cobrinha e obstáculos que ela terá de transpor. 


Exemplo de comida 


Exemplo de cobrinha 


Exemplo de obstáculo 
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O início do jogo 
Você precisará distribuir, em posições geradas aleatoriamente, 10 obstáculos e 15 comidas. 
A direção de movimento inicial da cobrinha deverá ser gerada aleatoriamente pelo programa (para 
cima, para baixo, para esquerda ou para direita). 
Você deverá estipular um tempo de duração do jogo. 
O jogador começará o jogo com cinco vidas. 
Movimento da cobrinha 
A cobrinha se movimentará em uma direção até que o usuário aperte uma das teclas de direção (—1—]) 
para alterar sua trajetória. 
Atenção: A cobrinha não pode passar por cima dela mesma, por isso: 
se a cobrinha estiver subindo, não aceite que o usuário aperte a tecla ]; 
se a cobrinha estiver descendo, não aceite que o usuário aperte a tecla 7; 
se a cobrinha estiver indo para a esquerda, não aceite que o usuário aperte a tecla —; 


se a cobrinha estiver indo para a direita, não aceite que o usuário aperte a tecla —. 


A cobrinha não poderá ultrapassar os limites da janela definida por você. 

Então, se a cobrinha: 
estiver subindo, chegar à borda, e se sua trajetória não for alterada, deverá ir desaparecendo da 
parte superior e ir aparecendo na parte inferior da janela (mantendo a mesma coluna); 


estiver descendo, chegar à borda, e se sua trajetória não for alterada, deverá ir desaparecendo da 
parte inferior e ir aparecendo na parte superior da janela (mantendo a mesma coluna); 


estiver indo para a esquerda, chegar à borda, e se sua trajetória não for alterada, deverá ir desapa- 
recendo da lateral esquerda e ir aparecendo na lateral direita da janela (mantendo a mesma linha); 


estiver indo para a direita, chegar à borda, e se sua trajetória não for alterada, deverá ir desapare- 
cendo da lateral direita e ir aparecendo na lateral esquerda da janela (mantendo a mesma linha). 
A comida 
Quando a cabeça da cobrinha atingir a mesma coordenada de uma comida, esta será ingerida e deverá 
sumir da tela. Para cada três comidas ingeridas, o jogador ganha uma vida. 


O obstáculo 
Quando a cabeça da cobrinha atingir a mesma coordenada de um obstáculo, este deverá sumir da tela. 
Para cada obstáculo atingido, o jogador perde uma vida. 


O fim do jogo 

O jogo termina quando: 

1. a cobrinha comer todas as comidas. Nesse caso, o jogador ganhou o jogo; 
2. acabaram as vidas. Nesse caso, o jogador perde o jogo; 

3. o tempo acabou. Nesse caso, o jogador perde o jogo. 


Dica: Pesquise funções que detectam qual tecla foi pressionada em determinado momento. 


13.23 Desafio 23 


Um banco possui vários tipos de contas bancárias: (1) conta-corrente simples; (2) conta-corrente espe- 
cial; (3) conta poupança. 

Todas as contas possuem um número, um titular e um saldo. Para cada uma delas, entretanto, existem 
peculiaridades. 


Conta corrente simples: tem direito a um cartão de débito (guardar o número) e um talão de cheques (guar- 
dar o número do primeiro e do último cheque do talão), mas não tem direito a limite e nem cheque especial; 
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Conta corrente especial: tem tudo o que a conta simples possui, mais o limite de crédito concedido pelo 
banco e taxa de juros cobrada pelo uso do limite; 


Conta poupança: tem tudo o que a conta simples possui, mais uma data de aniversário (o dia do mês em 
que os rendimentos são creditados). 


Defina as classes anteriores, utilizando herança onde for apropriado. 


Crie uma aplicação que gere uma conta de cada tipo e cadastre (nos métodos construtores) as informa- 
ções pertinentes a cada uma das contas. 

Depois que as contas estiverem cadastradas, seu programa deverá mostrar um menu com opções para 
visualização das contas e para atualização do saldo de cada conta, lembrando que: para as contas simples, 
o saldo está sempre atualizado; para as contas especiais, o valor do limite utilizado deverá ser subtraído do 
saldo, e, para as contas poupanças, o saldo deverá ser acrescido do rendimento (vamos supor 2% ao mês). 


13.24 Desafio 24 


Um promoter deseja controlar todos os eventos dos quais participa e você foi contratado para resolver 
esse problema. 

Assim que começou o trabalho, você ficou sabendo que o cadastro de um evento necessita de: identifi- 
cador único (um código), descrição, local e data de realização, quantidade de convites colocados à venda, 
custos de organização e valor da entrada. 

Foi-lhe informado, também, que existem sempre três valores de entrada: o 1º valor é para as entradas 
do tipo popular, o 2º valor é para as entradas do tipo normal e o 3º valor é para as entradas do tipo VIP. 

Alguns desses eventos são festas open bar, possuindo, assim, além de todas as informações anteriores, 
uma relação das quatro bebidas que serão servidas. As informações da bebida, por sua vez, são nome, teor 
alcoólico e valor unitário. 

O valor das entradas populares pode ser informado pelo usuário ou pode ser calculado automatica- 
mente, da seguinte forma: 


eventos open bar: R$ 30,00 mais 50% do valor unitário de cada bebida que será servida; 


demais eventos: custo de organização dividido pela quantidade de convites colocados a venda. 


O valor da entrada normal é o valor da popular + 10% desse mesmo valor. O valor da entrada VIP é o 
valor da normal + 15% desse mesmo valor. 

Implemente classes que representem esse contexto. Utilize, onde apropriado, todos os conceitos de 
orientação a objetos já estudados (herança, composição, polimorfismo, sobrecarga e sobreposição de mé- 
todos etc.). 

Crie, também, uma classe aplicação que permita o cadastramento de cinco eventos (que podem ser 
open bar ou não, dependendo do usuário). 

Durante o cadastramento, deverão ser calculados, nas classes apropriadas, os valores das entradas, de 
acordo com o desejo do usuário e seguindo as regras de negócio, descritas anteriormente. 

Mostre, quando o usuário desejar, todas as informações de todos os eventos cadastrados. 


13.25 Desafio 25 


Implemente um jogo que siga as regras descritas a seguir: 
1. Ojogo deverá ser jogado em um tabuleiro com 64 casas (8 x 8). 


2. As pedras sempre são dispostas nas casas de cor escura. Como, nesse jogo, não haverá recursos visu- 
ais, as pedras dos participantes deverão ser dispostas de tal forma que consigam percorrer as mesmas 
diagonais. Sugere-se uma disposição conforme a figura a seguir. 
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As pedras do jogador A ficarão 
dispostas nas casas pretas. 


10. 


11. 


12. 
13. 


14. 


As pedras do jogador B 
também ficarão dispostas nas 
casas pretas. 


As pedras dos jogadores deverão ser representadas na tela por caracteres diferentes (por exemplo, 
para o jogador À utilizar o símbolo O e para o jogador B utilizar o símbolo X). 


As pedras devem se movimentar sempre em diagonal e para a frente (exceto quando for tomar — 
comer — uma pedra do adversário, situação em que é permitido movimentar-se para trás). 


Quando uma pedra atravessar todo o tabuleiro, será coroada como “dama”. Essa pedra deverá ser 
destacada das demais com um tipo diferente de caractere. 


Em cada jogada, o jogador tem obrigação de tomar — “comer” — todas as pedras possíveis do seu 
adversário. Caso isso não seja feito ocorrerá um “sopro”, o jogador perderá a pedra que não realizou 
todas as tomadas necessárias. 


Uma pedra simples pode mover-se apenas uma casa por vez. Exceto quando for comer outra pedra, 
quando acabará movimentando-se duas casas. 


Uma pedra comum poderá comer uma pedra do adversário se, e somente se, conseguir pular esta pe- 
dra (por exemplo: a pedra localizada na linha 3 coluna 1 poderá comer a pedra da linha 4 coluna 2). 


Uma dama poderá percorrer várias casas em uma diagonal. Assim, poderá comer pedras que estejam 
distantes dela (por exemplo, uma dama na linha 4 coluna 2 poderá comer uma pedra na linha 7 co- 
luna 5, reposicionando-se na linha 8, coluna 6). 

O salto de uma dama só é impedido por uma obstrução, ou seja, quando na mesma diagonal houver 
outra pedra do mesmo jogador ou duas ou mais pedras do adversário em posições contíguas. 

As tomadas podem ser simples ou em cadeia. Tomada simples é aquela na qual apenas uma pedra é 
comida. Tomada em cadeia é aquela em que várias pedras são comidas numa mesma jogada, ou seja, 
ao término de uma tomada verifica-se a possibilidade de realizar outra e, assim, sucessivamente. 

As jogadas acontecem alternadamente entre os dois jogadores. 

Para cada jogada, o jogador deverá informar qual pedra deseja movimentar (informar número da 
linha e da coluna) e para onde deseja movimentá-la (mais uma vez, informará o número da linha e o 
da coluna). 


Depois disso, seu programa deverá fazer todas as validações necessárias, de acordo com as regras 
apresentadas anteriormente. 
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15. Será campeão o jogador que acabar com todas as pedras do adversário ou deixá-las sem condição de 
jogo. 


16. Acontecerá um empate quando houver vinte jogadas envolvendo apenas damas, sem que haja toma- 
das, ou seja, nenhuma pedra é “comida”. 


Essa aplicação deverá seguir os conceitos da orientação a objetos. Isso quer dizer que vocês 
deverão identificar quais classes estão presentes nesse problema. 


Após delimitar as classes, definir quais são as responsabilidades de cada uma. 
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Execução da função, 424, 426, 433-4 
Exemplo, 
de function, 259-60 
de matriz, 201, 208 
de vetor, 151, 153, 155, 157 
Exemplos, 
de algoritmos, 4 
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Sequência de variáveis, 201, 213 
shortint, tipo de dado, 21 
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